LLVM 19.0.0git
Classes | Public Types | Public Member Functions | Public Attributes | List of all members
llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext Struct Reference

Keeps track of data associated with one object during linking. More...

#include "DWARFLinker/Parallel/DWARFLinkerImpl.h"

Inheritance diagram for llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext:
Inheritance graph
[legend]

Classes

struct  RefModuleUnit
 Keep information for referenced clang module: already loaded DWARF info of the clang module and a CompileUnit of the module. More...
 

Public Types

using UnitListTy = SmallVector< std::unique_ptr< CompileUnit > >
 
using ModuleUnitListTy = SmallVector< RefModuleUnit >
 

Public Member Functions

 LinkContext (LinkingGlobalData &GlobalData, DWARFFile &File, StringMap< uint64_t > &ClangModules, std::atomic< size_t > &UniqueUnitID)
 
std::pair< bool, boolisClangModuleRef (const DWARFDie &CUDie, std::string &PCMFile, unsigned Indent, bool Quiet)
 Check whether specified CUDie is a Clang module reference.
 
bool registerModuleReference (const DWARFDie &CUDie, ObjFileLoaderTy Loader, CompileUnitHandlerTy OnCUDieLoaded, unsigned Indent=0)
 If this compile unit is really a skeleton CU that points to a clang module, register it in ClangModules and return true.
 
Error loadClangModule (ObjFileLoaderTy Loader, const DWARFDie &CUDie, const std::string &PCMFile, CompileUnitHandlerTy OnCUDieLoaded, unsigned Indent=0)
 Recursively add the debug info in this clang module .pcm file (and all the modules imported by it in a bottom-up fashion) to ModuleUnits.
 
void addModulesCompileUnit (RefModuleUnit &&Unit)
 Add Compile Unit corresponding to the module.
 
uint64_t getInputDebugInfoSize () const
 Computes the total size of the debug info.
 
Error link (TypeUnit *ArtificialTypeUnit)
 Link compile units for this context.
 
void linkSingleCompileUnit (CompileUnit &CU, TypeUnit *ArtificialTypeUnit, enum CompileUnit::Stage DoUntilStage=CompileUnit::Stage::Cleaned)
 Link specified compile unit until specified stage.
 
Error emitInvariantSections ()
 Emit invariant sections.
 
Error cloneAndEmitDebugFrame ()
 Clone and emit .debug_frame.
 
void emitFDE (uint32_t CIEOffset, uint32_t AddrSize, uint64_t Address, StringRef FDEBytes, SectionDescriptor &Section)
 Emit FDE record.
 
- Public Member Functions inherited from llvm::dwarf_linker::parallel::OutputSections
 OutputSections (LinkingGlobalData &GlobalData)
 
void setOutputFormat (dwarf::FormParams Format, llvm::endianness Endianness)
 Sets output format for all keeping sections.
 
const SectionDescriptorgetSectionDescriptor (DebugSectionKind SectionKind) const
 Returns descriptor for the specified section of SectionKind.
 
SectionDescriptorgetSectionDescriptor (DebugSectionKind SectionKind)
 Returns descriptor for the specified section of SectionKind.
 
std::optional< const SectionDescriptor * > tryGetSectionDescriptor (DebugSectionKind SectionKind) const
 Returns descriptor for the specified section of SectionKind.
 
std::optional< SectionDescriptor * > tryGetSectionDescriptor (DebugSectionKind SectionKind)
 Returns descriptor for the specified section of SectionKind.
 
SectionDescriptorgetOrCreateSectionDescriptor (DebugSectionKind SectionKind)
 Returns descriptor for the specified section of SectionKind.
 
void eraseSections ()
 Erases data of all sections.
 
void forEach (function_ref< void(SectionDescriptor &)> Handler)
 Enumerate all sections and call Handler for each.
 
void forEach (function_ref< void(std::shared_ptr< SectionDescriptor > Section)> Handler)
 Enumerate all sections and call Handler for each.
 
void assignSectionsOffsetAndAccumulateSize (std::array< uint64_t, SectionKindsNum > &SectionSizesAccumulator)
 Enumerate all sections, for each section set current offset (kept by SectionSizesAccumulator), update current offset with section length.
 
void applyPatches (SectionDescriptor &Section, StringEntryToDwarfStringPoolEntryMap &DebugStrStrings, StringEntryToDwarfStringPoolEntryMap &DebugLineStrStrings, TypeUnit *TypeUnitPtr)
 Enumerate all sections, for each section apply all section patches.
 
llvm::endianness getEndianness () const
 Endiannes for the sections.
 
uint16_t getVersion () const
 Return DWARF version.
 
uint16_t getDebugInfoHeaderSize () const
 Return size of header of debug_info table.
 
uint16_t getDebugAddrHeaderSize () const
 Return size of header of debug_ table.
 
uint16_t getDebugStrOffsetsHeaderSize () const
 Return size of header of debug_str_offsets table.
 
const dwarf::FormParamsgetFormParams () const
 Return size of address.
 

Public Attributes

DWARFFileInputDWARFFile
 Object file descriptor.
 
UnitListTy CompileUnits
 Set of Compilation Units(may be accessed asynchroniously for reading).
 
ModuleUnitListTy ModulesCompileUnits
 Set of Compile Units for modules.
 
uint64_t OriginalDebugInfoSize = 0
 Size of Debug info before optimizing.
 
bool InterCUProcessingStarted = false
 Flag indicating that all inter-connected units are loaded and the dwarf linking process for these units is started.
 
StringMap< uint64_t > & ClangModules
 
std::atomic< boolHasNewInterconnectedCUs = {false}
 Flag indicating that new inter-connected compilation units were discovered.
 
std::atomic< boolHasNewGlobalDependency = {false}
 
std::atomic< size_t > & UniqueUnitID
 Counter for compile units ID.
 
std::function< CompileUnit *(uint64_t)> getUnitForOffset
 

Additional Inherited Members

- Protected Types inherited from llvm::dwarf_linker::parallel::OutputSections
using SectionsSetTy = std::map< DebugSectionKind, std::shared_ptr< SectionDescriptor > >
 All keeping sections.
 
- Protected Attributes inherited from llvm::dwarf_linker::parallel::OutputSections
LinkingGlobalDataGlobalData
 
dwarf::FormParams Format = {4, 4, dwarf::DWARF32}
 Format for sections.
 
llvm::endianness Endianness = llvm::endianness::native
 Endiannes for sections.
 
SectionsSetTy SectionDescriptors
 

Detailed Description

Keeps track of data associated with one object during linking.

i.e. source file descriptor, compilation units, output data for compilation units common tables.

Definition at line 161 of file DWARFLinkerImpl.h.

Member Typedef Documentation

◆ ModuleUnitListTy

Definition at line 174 of file DWARFLinkerImpl.h.

◆ UnitListTy

Definition at line 162 of file DWARFLinkerImpl.h.

Constructor & Destructor Documentation

◆ LinkContext()

DWARFLinkerImpl::LinkContext::LinkContext ( LinkingGlobalData GlobalData,
DWARFFile File,
StringMap< uint64_t > &  ClangModules,
std::atomic< size_t > &  UniqueUnitID 
)

Member Function Documentation

◆ addModulesCompileUnit()

void DWARFLinkerImpl::LinkContext::addModulesCompileUnit ( LinkContext::RefModuleUnit &&  Unit)

Add Compile Unit corresponding to the module.

Definition at line 57 of file DWARFLinkerImpl.cpp.

References llvm::SmallVectorImpl< T >::emplace_back(), and ModulesCompileUnits.

◆ cloneAndEmitDebugFrame()

Error DWARFLinkerImpl::LinkContext::cloneAndEmitDebugFrame ( )

◆ emitFDE()

void DWARFLinkerImpl::LinkContext::emitFDE ( uint32_t  CIEOffset,
uint32_t  AddrSize,
uint64_t  Address,
StringRef  FDEBytes,
SectionDescriptor Section 
)

Emit FDE record.

Emit a FDE into the debug_frame section.

FDEBytes contains the FDE data without the length, CIE offset and address which will be replaced with the parameter values.

Definition at line 842 of file DWARFLinkerImpl.cpp.

References llvm::Address, llvm::StringRef::data(), and llvm::StringRef::size().

Referenced by cloneAndEmitDebugFrame().

◆ emitInvariantSections()

Error DWARFLinkerImpl::LinkContext::emitInvariantSections ( )

◆ getInputDebugInfoSize()

uint64_t llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::getInputDebugInfoSize ( ) const
inline

Computes the total size of the debug info.

Definition at line 238 of file DWARFLinkerImpl.h.

References llvm::dwarf_linker::DWARFFile::Dwarf, InputDWARFFile, and Size.

Referenced by link().

◆ isClangModuleRef()

std::pair< bool, bool > DWARFLinkerImpl::LinkContext::isClangModuleRef ( const DWARFDie CUDie,
std::string &  PCMFile,
unsigned  Indent,
bool  Quiet 
)

◆ link()

Error DWARFLinkerImpl::LinkContext::link ( TypeUnit ArtificialTypeUnit)

Link compile units for this context.

Definition at line 447 of file DWARFLinkerImpl.cpp.

References llvm::dwarf_linker::DWARFFile::Addresses, llvm::dwarf_linker::parallel::DWARFLinkerImpl::ArtificialTypeUnit, llvm::SmallVectorTemplateCommon< T, typename >::back(), llvm::dwarf_linker::parallel::CompileUnit::Cleaned, cloneAndEmitDebugFrame(), llvm::dwarf_linker::parallel::CompileUnit::Cloned, CompileUnits, llvm::dwarf_linker::DWARFFile::Dwarf, emitInvariantSections(), llvm::SmallVectorImpl< T >::emplace_back(), llvm::SmallVectorBase< Size_T >::empty(), llvm::dwarf_linker::finiteLoop(), llvm::dwarf_linker::parallel::OutputSections::getEndianness(), getInputDebugInfoSize(), llvm::dwarf_linker::parallel::LinkingGlobalData::getOptions(), llvm::getPCMFile(), getUnitForOffset, llvm::dwarf_linker::parallel::OutputSections::GlobalData, HasNewGlobalDependency, HasNewInterconnectedCUs, InputDWARFFile, InterCUProcessingStarted, isClangModuleRef(), linkSingleCompileUnit(), llvm::dwarf_linker::parallel::CompileUnit::LivenessAnalysisDone, ModulesCompileUnits, llvm::dwarf_linker::parallel::DWARFLinkerOptions::ObjectPrefixMap, OriginalDebugInfoSize, llvm::outs(), llvm::parallelForEach(), llvm::dwarf_linker::parallel::CompileUnit::PatchesUpdated, llvm::parallel::TaskGroup::spawn(), llvm::Error::success(), llvm::dwarf_linker::parallel::CompileUnit::TypeNamesAssigned, UniqueUnitID, llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::RefModuleUnit::Unit, llvm::dwarf_linker::parallel::CompileUnit::UpdateDependenciesCompleteness, llvm::dwarf_linker::parallel::DWARFLinkerOptions::UpdateIndexTablesOnly, and llvm::dwarf_linker::parallel::DWARFLinkerOptions::Verbose.

◆ linkSingleCompileUnit()

void DWARFLinkerImpl::LinkContext::linkSingleCompileUnit ( CompileUnit CU,
TypeUnit ArtificialTypeUnit,
enum CompileUnit::Stage  DoUntilStage = CompileUnit::Stage::Cleaned 
)

◆ loadClangModule()

Error DWARFLinkerImpl::LinkContext::loadClangModule ( ObjFileLoaderTy  Loader,
const DWARFDie CUDie,
const std::string &  PCMFile,
CompileUnitHandlerTy  OnCUDieLoaded,
unsigned  Indent = 0 
)

◆ registerModuleReference()

bool DWARFLinkerImpl::LinkContext::registerModuleReference ( const DWARFDie CUDie,
ObjFileLoaderTy  Loader,
CompileUnitHandlerTy  OnCUDieLoaded,
unsigned  Indent = 0 
)

If this compile unit is really a skeleton CU that points to a clang module, register it in ClangModules and return true.

A skeleton CU is a CU without children, a DW_AT_gnu_dwo_name pointing to the module, and a DW_AT_gnu_dwo_id with the module hash.

Definition at line 343 of file DWARFLinkerImpl.cpp.

References ClangModules, llvm::consumeError(), llvm::getDwoId(), llvm::dwarf_linker::parallel::LinkingGlobalData::getOptions(), llvm::getPCMFile(), llvm::dwarf_linker::parallel::OutputSections::GlobalData, llvm::StringMap< ValueTy, AllocatorTy >::insert(), isClangModuleRef(), loadClangModule(), llvm::dwarf_linker::parallel::DWARFLinkerOptions::ObjectPrefixMap, llvm::outs(), and llvm::dwarf_linker::parallel::DWARFLinkerOptions::Verbose.

Referenced by loadClangModule().

Member Data Documentation

◆ ClangModules

StringMap<uint64_t>& llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::ClangModules

◆ CompileUnits

UnitListTy llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::CompileUnits

Set of Compilation Units(may be accessed asynchroniously for reading).

Definition at line 180 of file DWARFLinkerImpl.h.

Referenced by cloneAndEmitDebugFrame(), link(), and LinkContext().

◆ getUnitForOffset

std::function<CompileUnit *(uint64_t)> llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::getUnitForOffset
Initial value:
=
[&](uint64_t Offset) -> CompileUnit * {
[](uint64_t LHS, const std::unique_ptr<CompileUnit> &RHS) {
return LHS < RHS->getOrigUnit().getNextUnitOffset();
});
return CU != CompileUnits.end() ? CU->get() : nullptr;
}
Value * RHS
Value * LHS
@ Offset
Definition: DWP.cpp:456
auto upper_bound(R &&Range, T &&Value)
Provide wrappers to std::upper_bound which take ranges instead of having to pass begin/end explicitly...
Definition: STLExtras.h:1967
UnitListTy CompileUnits
Set of Compilation Units(may be accessed asynchroniously for reading).

Definition at line 268 of file DWARFLinkerImpl.h.

Referenced by link(), and loadClangModule().

◆ HasNewGlobalDependency

std::atomic<bool> llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::HasNewGlobalDependency = {false}

Definition at line 199 of file DWARFLinkerImpl.h.

Referenced by link(), and linkSingleCompileUnit().

◆ HasNewInterconnectedCUs

std::atomic<bool> llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::HasNewInterconnectedCUs = {false}

Flag indicating that new inter-connected compilation units were discovered.

It is used for restarting units processing if new inter-connected units were found.

Definition at line 197 of file DWARFLinkerImpl.h.

Referenced by link().

◆ InputDWARFFile

DWARFFile& llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::InputDWARFFile

◆ InterCUProcessingStarted

bool llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::InterCUProcessingStarted = false

Flag indicating that all inter-connected units are loaded and the dwarf linking process for these units is started.

Definition at line 190 of file DWARFLinkerImpl.h.

Referenced by link(), and linkSingleCompileUnit().

◆ ModulesCompileUnits

ModuleUnitListTy llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::ModulesCompileUnits

Set of Compile Units for modules.

Definition at line 183 of file DWARFLinkerImpl.h.

Referenced by addModulesCompileUnit(), link(), and loadClangModule().

◆ OriginalDebugInfoSize

uint64_t llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::OriginalDebugInfoSize = 0

Size of Debug info before optimizing.

Definition at line 186 of file DWARFLinkerImpl.h.

Referenced by link().

◆ UniqueUnitID

std::atomic<size_t>& llvm::dwarf_linker::parallel::DWARFLinkerImpl::LinkContext::UniqueUnitID

The documentation for this struct was generated from the following files: