38 if (!File.Dwarf->compile_units().empty())
39 CompileUnits.reserve(File.Dwarf->getNumCompileUnits());
42 Format.Version = File.Dwarf->getMaxVersion();
43 Format.AddrSize = File.Dwarf->getCUAddrSize();
44 Endianness = File.Dwarf->isLittleEndian() ? llvm::endianness::little
45 : llvm::endianness::big;
68 for (
const std::unique_ptr<DWARFUnit> &
CU :
79 if (!
GlobalData.getOptions().UpdateIndexTablesOnly)
103 if (std::optional<std::reference_wrapper<const Triple>> CurTriple =
105 GlobalEndianness = (*CurTriple).get().isLittleEndian()
109 std::optional<uint16_t> Language;
112 if (Context->InputDWARFFile.Dwarf ==
nullptr) {
113 Context->setOutputFormat(Context->getFormParams(), GlobalEndianness);
118 outs() <<
"DEBUG MAP OBJECT: " << Context->InputDWARFFile.FileName
121 for (
const std::unique_ptr<DWARFUnit> &OrigCU :
122 Context->InputDWARFFile.Dwarf->compile_units()) {
123 outs() <<
"Input compilation unit:";
127 OrigCU->getUnitDIE().dump(
outs(), 0, DumpOpts);
136 GlobalEndianness = Context->getEndianness();
138 std::max(GlobalFormat.
AddrSize, Context->getFormParams().AddrSize);
140 Context->setOutputFormat(Context->getFormParams(), GlobalEndianness);
145 for (
const std::unique_ptr<DWARFUnit> &OrigCU :
146 Context->InputDWARFFile.Dwarf->compile_units()) {
147 DWARFDie UnitDie = OrigCU->getUnitDIE();
150 if (std::optional<DWARFFormValue> Val =
151 UnitDie.
find(dwarf::DW_AT_language)) {
161 if (std::optional<std::reference_wrapper<const Triple>> TargetTriple =
163 GlobalFormat.
AddrSize = (*TargetTriple).get().isArch32Bit() ? 4 : 8;
170 if (!
GlobalData.Options.NoODR && Language.has_value()) {
190 GlobalData.error(std::move(Err), Context->InputDWARFFile.FileName);
191 if (
Error Err = Context->unloadInput())
192 GlobalData.error(std::move(Err), Context->InputDWARFFile.FileName);
200 GlobalData.error(std::move(Err), Context->InputDWARFFile.FileName);
201 if (
Error Err = Context->unloadInput())
202 GlobalData.error(std::move(Err), Context->InputDWARFFile.FileName);
212 GlobalData.Options.ParseableSwiftInterfaces) {
215 Context->ModulesCompileUnits)
216 ModuleUnit.
Unit->mergeSwiftInterfaces(*SwiftInterfaces);
217 for (std::unique_ptr<CompileUnit> &
CU : Context->CompileUnits)
218 CU->mergeSwiftInterfaces(*SwiftInterfaces);
224 if (!
GlobalData.getOptions().UpdateIndexTablesOnly) {
227 if (Context->FrameScan)
228 Context->registerCIEs(CIEs);
232 if (!Context->FrameScan)
235 if (
Error Err = Context->emitDebugFrame(CIEs))
236 GlobalData.error(std::move(Err), Context->InputDWARFFile.FileName);
245 ->Children.empty()) {
267 if (
GlobalData.getOptions().InputVerificationHandler)
268 GlobalData.getOptions().InputVerificationHandler(File, OS.
str());
273 if (
GlobalData.getOptions().TargetDWARFVersion == 0)
275 "target DWARF version is not set");
280 "set number of threads to 1 to make --verbose to work properly.",
"");
284 if (
GlobalData.getOptions().UpdateIndexTablesOnly &&
299 CUDie.
find({dwarf::DW_AT_dwo_id, dwarf::DW_AT_GNU_dwo_id}));
308 if (ObjectPrefixMap.empty())
312 for (
const auto &Entry : ObjectPrefixMap)
315 return p.str().str();
321 CUDie.
find({dwarf::DW_AT_dwo_name, dwarf::DW_AT_GNU_dwo_name}),
"");
327 PCMFile =
remapPath(PCMFile, *ObjectPrefixMap);
333 const DWARFDie &CUDie, std::string &PCMFile,
unsigned Indent,
bool Quiet) {
335 return std::make_pair(
false,
false);
343 GlobalData.warn(
"anonymous module skeleton CU for " + PCMFile +
".",
345 return std::make_pair(
true,
true);
350 outs() <<
"Found clang module reference " << PCMFile;
358 if (!
Quiet &&
GlobalData.getOptions().Verbose && (Cached->second != DwoId))
360 Twine(
"hash mismatch: this object file was built against a "
361 "different version of the module ") +
365 outs() <<
" [cached].\n";
366 return std::make_pair(
true,
true);
369 return std::make_pair(
true,
false);
381 std::string PCMFile =
383 std::pair<bool, bool> IsClangModuleRef =
386 if (!IsClangModuleRef.first)
389 if (IsClangModuleRef.second)
422 if (Loader ==
nullptr) {
423 GlobalData.error(
"cann't load clang module: loader is not specified.",
432 std::unique_ptr<CompileUnit> Unit;
433 for (
const auto &
CU : ErrOrObj->Dwarf->compile_units()) {
436 auto ChildCUDie =
CU->getUnitDIE();
443 ": Clang modules are expected to have exactly 1 compile unit.\n");
451 if (PCMDwoId != DwoId) {
454 Twine(
"hash mismatch: this object file was built against a "
455 "different version of the module ") +
463 if (!ChildCUDie.hasChildren())
467 Unit = std::make_unique<CompileUnit>(
505 if (!
GlobalData.getOptions().UpdateIndexTablesOnly &&
508 outs() <<
"No valid relocations found. Skipping.\n";
516 for (
const auto &OrigCU :
InputDWARFFile.Dwarf->compile_units()) {
518 auto CUDie = OrigCU->getUnitDIE();
519 std::string PCMFile =
524 if (!CUDie ||
GlobalData.getOptions().UpdateIndexTablesOnly ||
526 CompileUnits.emplace_back(std::make_unique<CompileUnit>(
555 if (
CU->isInterconnectedCU()) {
556 CU->maybeResetToLoadedStage();
584 if (
CU->isInterconnectedCU() &&
614 if (
GlobalData.getOptions().UpdateIndexTablesOnly) {
631 if (
CU.getStage() >= DoUntilStage)
634 switch (
CU.getStage()) {
638 if (!
CU.loadInputDIEs()) {
643 CU.analyzeDWARFStructure();
651 CU.getOrigUnit().getUnitDIE(),
nullptr,
665 "Flag indicating new inter-connections is not set");
674 if (
CU.updateDependenciesCompleteness())
679 return CU.updateDependenciesCompleteness();
681 return std::move(Err);
689 CU.verifyDependencies();
695 return std::move(Err);
702 if (
CU.isClangModule() ||
703 GlobalData.getOptions().UpdateIndexTablesOnly ||
704 CU.getContaingFile().Addresses->hasValidRelocs()) {
707 return std::move(Err);
715 CU.updateDieRefPatchesWithClonedOffsets();
721 CU.cleanupDataAfterClonning();
736 CU.error(std::move(Err));
737 CU.cleanupDataAfterClonning();
743 if (!
GlobalData.getTargetTriple().has_value())
765 if (
GlobalData.getOptions().UpdateIndexTablesOnly)
767 if (!
GlobalData.getTargetTriple().has_value())
778 if (OrigFrameData.
empty())
781 auto Scan = std::make_unique<FrameScanResult>();
782 Scan->FrameData = OrigFrameData;
786 for (std::unique_ptr<CompileUnit> &Unit :
CompileUnits) {
787 for (
auto CurRange : Unit->getFunctionRanges())
788 AllUnitsRanges.
insert(CurRange.Range, CurRange.Value);
794 const unsigned SrcAddrSize = Scan->AddressSize;
797 constexpr unsigned CIEPointerSize = 4;
803 while (
Data.isValidOffset(InputOffset)) {
806 if (InitialLength == 0xFFFFFFFF)
809 "Dwarf64 bits not supported"));
814 if (InitialLength > FrameBytes.
size() - InputOffset)
818 "Truncated .debug_frame entry."));
821 if (CIEId == 0xFFFFFFFF) {
824 LocalCIEs[EntryOffset] = CIEData;
826 InputOffset += InitialLength - 4;
836 std::optional<AddressRangeValuePair>
Range =
840 InputOffset = EntryOffset + InitialLength + 4;
850 "Inconsistent debug_frame content. Dropping."));
855 if (InitialLength < CIEPointerSize + SrcAddrSize)
858 "Truncated .debug_frame FDE."));
862 if (AddedCIEs.
insert(CIEId).second)
863 Scan->CIEs.push_back(CIEData);
865 unsigned FDERemainingBytes = InitialLength - (CIEPointerSize + SrcAddrSize);
866 Scan->FDEs.push_back({CIEData,
Loc +
Range->Value,
867 FrameBytes.
substr(InputOffset, FDERemainingBytes)});
868 InputOffset += FDERemainingBytes;
882 auto [It, Inserted] =
885 FrameScan->OwnedCIEs.push_back(CIEBytes);
886 NextLocalOffset +=
static_cast<uint32_t>(CIEBytes.
size());
898 OutSection.
OS << CIEBytes;
901 const unsigned SrcAddrSize =
FrameScan->AddressSize;
905 assert(It != CIEs.
end() &&
"CIE missing from registry");
907 const uint32_t CIELocalOffset = It->second.LocalOffset;
916 if (FDEPos >
FP.getDwarfMaxOffset())
951 Section.emitIntVal(FDEBytes.
size() + 4 + AddrSize, 4);
952 Section.emitIntVal(CIEOffset, 4);
953 Section.emitIntVal(
Address, AddrSize);
954 Section.OS.write(FDEBytes.
data(), FDEBytes.
size());
958 if (!
GlobalData.getTargetTriple().has_value())
991 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts) {
992 uint64_t AllDebugInfoSectionsSize = 0;
994 for (std::unique_ptr<CompileUnit> &
CU : Context->CompileUnits)
995 if (std::optional<SectionDescriptor *>
DebugInfo =
997 AllDebugInfoSectionsSize += (*DebugInfo)->getContents().size();
999 auto &
Size = SizeByObject[Context->InputDWARFFile.FileName];
1000 Size.Input = Context->OriginalDebugInfoSize;
1001 Size.Output = AllDebugInfoSectionsSize;
1005 std::vector<std::pair<StringRef, DebugInfoSize>> Sorted;
1006 for (
auto &E : SizeByObject)
1007 Sorted.emplace_back(E.first(), E.second);
1008 llvm::sort(Sorted, [](
auto &LHS,
auto &RHS) {
1009 return LHS.second.Output > RHS.second.Output;
1012 auto ComputePercentange = [](int64_t
Input, int64_t Output) ->
float {
1013 const float Difference = Output -
Input;
1014 const float Sum =
Input + Output;
1017 return (Difference / (Sum / 2));
1020 int64_t InputTotal = 0;
1021 int64_t OutputTotal = 0;
1022 const char *FormatStr =
"{0,-45} {1,10}b {2,10}b {3,8:P}\n";
1025 outs() <<
".debug_info section size (in bytes)\n";
1026 outs() <<
"----------------------------------------------------------------"
1027 "---------------\n";
1028 outs() <<
"Filename Object "
1030 outs() <<
"----------------------------------------------------------------"
1031 "---------------\n";
1034 for (
auto &E : Sorted) {
1035 InputTotal += E.second.Input;
1036 OutputTotal += E.second.Output;
1039 E.second.Output, ComputePercentange(E.second.Input, E.second.Output));
1042 outs() <<
"----------------------------------------------------------------"
1043 "---------------\n";
1045 ComputePercentange(InputTotal, OutputTotal));
1046 outs() <<
"----------------------------------------------------------------"
1047 "---------------\n\n";
1057 size_t CurDebugStrIndex = 1;
1060 size_t CurDebugLineStrIndex = 0;
1061 uint64_t CurDebugLineStrOffset = 0;
1070 assert(Entry !=
nullptr);
1072 if (!Entry->isIndexed()) {
1073 Entry->Offset = CurDebugStrOffset;
1074 CurDebugStrOffset += Entry->String.size() + 1;
1075 Entry->Index = CurDebugStrIndex++;
1081 assert(Entry !=
nullptr);
1083 if (!Entry->isIndexed()) {
1084 Entry->Offset = CurDebugLineStrOffset;
1085 CurDebugLineStrOffset += Entry->String.size() + 1;
1086 Entry->Index = CurDebugLineStrIndex++;
1094 std::array<uint64_t, SectionKindsNum> SectionSizesAccumulator = {0};
1111 OutSection.ListDebugStrPatch.forEach([&](
DebugStrPatch &Patch) {
1121 StringHandler(
DebugStr, Info.String);
1127 OutSection.ListDebugStrPatch.forEach([&](
DebugStrPatch &Patch) {
1136 if (Patch.Die ==
nullptr)
1140 if (&
TypeEntry->getFinalDie() != Patch.Die)
1146 OutSection.ListDebugTypeLineStrPatch.forEach(
1148 if (Patch.Die ==
nullptr)
1152 if (&
TypeEntry->getFinalDie() != Patch.Die)
1168 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts)
1171 SectionsSetHandler(*ModuleUnit.
Unit);
1174 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts) {
1176 SectionsSetHandler(*Context);
1179 for (std::unique_ptr<CompileUnit> &
CU : Context->CompileUnits)
1181 SectionsSetHandler(*
CU);
1191 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts)
1194 UnitHandler(ModuleUnit.
Unit.get());
1197 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts)
1198 for (std::unique_ptr<CompileUnit> &
CU : Context->CompileUnits)
1200 UnitHandler(
CU.get());
1206 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts)
1209 UnitHandler(ModuleUnit.
Unit.get());
1212 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts)
1213 for (std::unique_ptr<CompileUnit> &
CU : Context->CompileUnits)
1215 UnitHandler(
CU.get());
1275 uint64_t DebugLineStrNextOffset = 0;
1280 .emitInplaceString(
"");
1281 DebugStrNextOffset++;
1294 if (StringToEmit->
Offset >= DebugStrNextOffset) {
1295 DebugStrNextOffset =
1299 .emitInplaceString(StringToEmit->
String);
1310 if (StringToEmit->
Offset >= DebugLineStrNextOffset) {
1311 DebugLineStrNextOffset =
1315 .emitInplaceString(StringToEmit->
String);
1330 uint64_t OutOffset = Info.OutOffset;
1331 switch (Info.Type) {
1361 Info.QualifiedNameHash);
1375 if (
Error Err =
Emitter.init(TargetTriple,
"__DWARF")) {
1396 if (
Error Err =
Emitter.init(TargetTriple,
"__DWARF")) {
1417 if (
Error Err =
Emitter.init(TargetTriple,
"__DWARF")) {
1438 if (
Error Err =
Emitter.init(TargetTriple,
"__DWARF")) {
1453 std::unique_ptr<DWARF5AccelTable>
DebugNames;
1461 bool HasRecords =
false;
1464 DebugNames = std::make_unique<DWARF5AccelTable>();
1467 switch (Info.Type) {
1472 Info.OutOffset, Info.ParentOffset, Info.Tag,
1474 CU->getTag() == dwarf::DW_TAG_type_unit);
1483 CompUnits.push_back(
1486 CUidToIdx[
CU->getUniqueID()] = Id++;
1498 if (
Error Err =
Emitter.init(TargetTriple,
"__DWARF")) {
1521 Sections.
forEach([&](std::shared_ptr<SectionDescriptor> OutSection) {
1529 CommonSections.forEach([&](std::shared_ptr<SectionDescriptor> OutSection) {
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
dxil DXContainer Global Emitter
static fatal_error_handler_t ErrorHandler
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
This class holds an abstract representation of an Accelerator Table, consisting of a sequence of buck...
std::optional< T > getRangeThatContains(uint64_t Addr) const
void insert(AddressRange Range, int64_t Value)
Utility class that carries the DWARF compile/type unit and the debug info entry in an object.
LLVM_ABI std::optional< DWARFFormValue > find(dwarf::Attribute Attr) const
Extract the specified attribute from this DIE.
virtual bool isLittleEndian() const =0
virtual const DWARFSection & getFrameSection() const
virtual uint8_t getAddressSize() const
ValueT lookup(const_arg_type_t< KeyT > Val) const
Return the entry for the specified key, or a default constructed value if no such entry exists.
Implements a dense probed hash-table based set.
Lightweight error class with error context and mandatory checking.
static ErrorSuccess success()
Create a success value.
Tagged union holding either a T or a Error.
void wait() override
Blocking wait for all the tasks to execute first.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
StringMap - This is an unconventional map that is specialized for handling keys that are "strings",...
iterator find(StringRef Key)
std::pair< iterator, bool > try_emplace(StringRef Key, ArgsTy &&...Args)
Emplace a new element for the specified key into the map if the key isn't already in the map.
Represent a constant reference to a string, i.e.
constexpr StringRef substr(size_t Start, size_t N=npos) const
Return a reference to the substring from [Start, Start + N).
constexpr bool empty() const
Check if the string is empty.
constexpr size_t size() const
Get the string size.
constexpr const char * data() const
Get a pointer to the start of the string (which may not be null terminated).
auto async(Function &&F, Args &&...ArgList)
Asynchronous submission of a task to the pool.
Triple - Helper class for working with autoconf configuration names.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
static Twine utohexstr(uint64_t Val)
std::pair< iterator, bool > insert(const ValueT &V)
This class represents DWARF information for source file and it's address map.
std::map< std::string, std::string > ObjectPrefixMapTy
function_ref< void(const DWARFUnit &Unit)> CompileUnitHandlerTy
std::function< void( const Twine &Warning, StringRef Context, const DWARFDie *DIE)> MessageHandlerTy
@ DebugNames
.debug_names.
@ Apple
.apple_names, .apple_namespaces, .apple_types, .apple_objc.
std::map< std::string, std::string > SwiftInterfacesMapTy
std::function< ErrorOr< DWARFFile & >( StringRef ContainerName, StringRef Path)> ObjFileLoaderTy
Stores all information related to a compile unit, be it in its original instance of the object file o...
Stage
The stages of new compile unit processing.
@ Cloned
Output DWARF is generated.
@ TypeNamesAssigned
Type names assigned to DIEs.
@ CreatedNotLoaded
Created, linked with input DWARF file.
@ PatchesUpdated
Offsets inside patch records are updated.
@ Cleaned
Resources(Input DWARF, Output DWARF tree) are released.
@ Loaded
Input DWARF is loaded.
@ LivenessAnalysisDone
Input DWARF is analysed(DIEs pointing to the real code section arediscovered, type names are assigned...
@ UpdateDependenciesCompleteness
Check if dependencies have incompatible placement.
@ Skipped
Compile Unit should be skipped.
void forEachObjectSectionsSet(function_ref< void(OutputSections &SectionsSet)> SectionsSetHandler)
Enumerates sections for modules, invariant for object files, compile units.
void emitDWARFv5DebugNamesSection(const Triple &TargetTriple)
Emit .debug_names section.
void writeCompileUnitsToTheOutput()
Enumerate all compile units and put their data into the output stream.
void forEachCompileUnit(function_ref< void(CompileUnit *CU)> UnitHandler)
Enumerates all comple units.
void assignOffsetsToStrings()
Enumerate all compile units and assign offsets to their strings.
void assignOffsets()
Enumerate all compile units and assign offsets to their sections and strings.
Error link() override
Link debug info for added files.
Error validateAndUpdateOptions()
Validate specified options.
void writeCommonSectionsToTheOutput()
Enumerate common sections and put their data into the output stream.
void assignOffsetsToSections()
Enumerate all compile units and assign offsets to their sections.
void printStatistic()
Print statistic for processed Debug Info.
void glueCompileUnitsAndWriteToTheOutput()
Take already linked compile units and glue them into single file.
void emitAppleAcceleratorSections(const Triple &TargetTriple)
Emit apple accelerator sections.
void verifyInput(const DWARFFile &File)
Verify input DWARF file.
void forEachCompileAndTypeUnit(function_ref< void(DwarfUnit *CU)> UnitHandler)
Enumerates all compile and type units.
void emitStringSections()
Emit string sections.
DWARFLinkerImpl(MessageHandlerTy ErrorHandler, MessageHandlerTy WarningHandler)
void addObjectFile(DWARFFile &File, ObjFileLoaderTy Loader=nullptr, CompileUnitHandlerTy OnCUDieLoaded=[](const DWARFUnit &) {}) override
Add object file to be linked.
void cleanupDataAfterDWARFOutputIsWritten()
Cleanup data(string pools) after output sections are generated.
void forEachOutputString(function_ref< void(StringDestinationKind, const StringEntry *)> StringHandler)
Enumerates all strings.
void emitCommonSectionsAndWriteCompileUnitsToTheOutput()
Emit debug sections common for all input files.
void patchOffsetsAndSizes()
Enumerates all patches and update them with the correct values.
This class emits DWARF data to the output stream.
Base class for all Dwarf units(Compile unit/Type table unit).
This class keeps data and services common for the whole linking process.
This class keeps contents and offsets to the debug sections.
void applyPatches(SectionDescriptor &Section, StringEntryToDwarfStringPoolEntryMap &DebugStrStrings, StringEntryToDwarfStringPoolEntryMap &DebugLineStrStrings, TypeUnit *TypeUnitPtr)
Enumerate all sections, for each section apply all section patches.
OutputSections(LinkingGlobalData &GlobalData)
LinkingGlobalData & GlobalData
void forEach(function_ref< void(SectionDescriptor &)> Handler)
Enumerate all sections and call Handler for each.
llvm::endianness getEndianness() const
Endiannes for the sections.
SectionDescriptor & getOrCreateSectionDescriptor(DebugSectionKind SectionKind)
Returns descriptor for the specified section of SectionKind.
void assignSectionsOffsetAndAccumulateSize(std::array< uint64_t, SectionKindsNum > &SectionSizesAccumulator)
Enumerate all sections, for each section set current offset (kept by SectionSizesAccumulator),...
const SectionDescriptor & getSectionDescriptor(DebugSectionKind SectionKind) const
Returns descriptor for the specified section of SectionKind.
Keeps cloned data for the type DIE.
Type Unit is used to represent an artificial compilation unit which keeps all type information.
An efficient, type-erasing, non-owning reference to a callable.
LLVM_ABI void spawn(std::function< void()> f)
uint64_t tell() const
tell - Return the current offset with the file.
raw_ostream & indent(unsigned NumSpaces)
indent - Insert 'NumSpaces' spaces.
A raw_ostream that writes to an std::string.
std::string & str()
Returns the string's reference.
LinkingGlobalData GlobalData
std::atomic< size_t > UniqueUnitID
Unique ID for compile unit.
uint64_t OverallNumberOfCU
Overall compile units number.
SmallVector< std::unique_ptr< LinkContext > > ObjectContexts
Keeps all linking contexts.
StringEntryToDwarfStringPoolEntryMap DebugLineStrStrings
DwarfStringPoolEntries for .debug_line_str section.
SectionHandlerTy SectionHandler
Hanler for output sections.
std::unique_ptr< TypeUnit > ArtificialTypeUnit
Type unit.
StringEntryToDwarfStringPoolEntryMap DebugStrStrings
DwarfStringPoolEntries for .debug_str section.
OutputSections CommonSections
Common sections.
StringMap< uint64_t > ClangModules
Mapping the PCM filename to the DwoId.
LLVM_ABI StringRef FormatString(DwarfFormat Format)
void setEstimatedObjfilesAmount(unsigned ObjFilesNum) override
Set estimated objects files amount, for preliminary data allocation.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
bool isODRLanguage(uint16_t Language)
std::vector< std::variant< MCSymbol *, uint64_t > > DebugNamesUnitsOffsets
DenseMap< unsigned, unsigned > CompUnitIDToIdx
StringMapEntry< std::atomic< TypeEntryBody * > > TypeEntry
StringMapEntry< EmptyStringSetTag > StringEntry
StringEntry keeps data of the string: the length, external offset and a string body which is placed r...
Error finiteLoop(function_ref< Expected< bool >()> Iteration, size_t MaxCounter=100000)
This function calls Iteration() until it returns false.
AddressRangesMap RangesTy
Mapped value in the address map is the offset to apply to the linked address.
std::optional< const char * > toString(const std::optional< DWARFFormValue > &V)
Take an optional DWARFFormValue and try to extract a string value from it.
@ DW_FLAG_type_implementation
std::optional< uint64_t > toUnsigned(const std::optional< DWARFFormValue > &V)
Take an optional DWARFFormValue and try to extract an unsigned constant.
LLVM_ABI ThreadPoolStrategy strategy
LLVM_ABI bool is_relative(const Twine &path, Style style=Style::native)
Is path relative?
LLVM_ABI StringRef filename(StringRef path LLVM_LIFETIME_BOUND, Style style=Style::native)
Get filename.
LLVM_ABI bool replace_path_prefix(SmallVectorImpl< char > &Path, StringRef OldPrefix, StringRef NewPrefix, Style style=Style::native)
Replace matching path prefix with another path.
LLVM_ABI void append(SmallVectorImpl< char > &path, const Twine &a, const Twine &b="", const Twine &c="", const Twine &d="")
Append to path.
This is an optimization pass for GlobalISel generic memory operations.
ThreadPoolStrategy hardware_concurrency(unsigned ThreadCount=0)
Returns a default thread strategy where all available hardware resources are to be used,...
Error createFileError(const Twine &F, Error E)
Concatenate a source file path and/or name with an Error.
LLVM_ABI std::error_code inconvertibleErrorCode()
The value returned by this function can be returned from convertToErrorCode for Error values where no...
LLVM_ABI raw_fd_ostream & outs()
This returns a reference to a raw_fd_ostream for standard output.
static std::string remapPath(StringRef Path, const DWARFLinkerBase::ObjectPrefixMapTy &ObjectPrefixMap)
Error createStringError(std::error_code EC, char const *Fmt, const Ts &... Vals)
Create formatted StringError object.
static void resolveRelativeObjectPath(SmallVectorImpl< char > &Buf, DWARFDie CU)
Resolve the relative path to a build artifact referenced by DWARF by applying DW_AT_comp_dir.
static std::string getPCMFile(const DWARFDie &CUDie, const DWARFLinkerBase::ObjectPrefixMapTy *ObjectPrefixMap)
auto formatv(bool Validate, const char *Fmt, Ts &&...Vals)
void sort(IteratorTy Start, IteratorTy End)
ThreadPoolStrategy optimal_concurrency(unsigned TaskCount=0)
Returns an optimal thread strategy to execute specified amount of tasks.
static uint64_t getDwoId(const DWARFDie &CUDie)
Error make_error(ArgTs &&... Args)
Make a Error instance representing failure using the given error info type.
@ Mod
The access may modify the value stored in memory.
FunctionAddr VTableAddr uintptr_t uintptr_t Data
SingleThreadExecutor DefaultThreadPool
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
void parallelForEach(IterTy Begin, IterTy End, FuncTy Fn)
void consumeError(Error Err)
Consume a Error without doing anything.
Implement std::hash so that hash_code can be used in STL containers.
Container for dump options that control which debug information will be dumped.
DIDumpOptions noImplicitRecursion() const
Return the options with RecurseDepth set to 0 unless explicitly required.
unsigned ChildRecurseDepth
DwarfStringPoolEntry with string keeping externally.
Section + local offset of a .debug_frame CIE that has been (or will be) emitted by some LinkContext.
FDEs retained for emission.
Keep information for referenced clang module: already loaded DWARF info of the clang module and a Com...
RefModuleUnit(DWARFFile &File, std::unique_ptr< CompileUnit > Unit)
std::unique_ptr< CompileUnit > Unit
uint64_t getInputDebugInfoSize() const
Computes the total size of the debug info.
bool InterCUProcessingStarted
Flag indicating that all inter-connected units are loaded and the dwarf linking process for these uni...
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 ClangModul...
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 ...
DWARFFile & InputDWARFFile
Object file descriptor.
std::unique_ptr< FrameScanResult > FrameScan
Error scanFrameData()
Parse this context's input .debug_frame into FrameScan.
uint64_t OriginalDebugInfoSize
Size of Debug info before optimizing.
Error emitInvariantSections()
Emit invariant sections.
std::pair< bool, bool > isClangModuleRef(const DWARFDie &CUDie, std::string &PCMFile, unsigned Indent, bool Quiet)
Check whether specified CUDie is a Clang module reference.
void addModulesCompileUnit(RefModuleUnit &&Unit)
Add Compile Unit corresponding to the module.
void emitFDE(uint32_t CIEOffset, uint32_t AddrSize, uint64_t Address, StringRef FDEBytes, SectionDescriptor &Section)
Emit FDE record.
UnitListTy CompileUnits
Set of Compilation Units(may be accessed asynchroniously for reading).
void linkSingleCompileUnit(CompileUnit &CU, TypeUnit *ArtificialTypeUnit, enum CompileUnit::Stage DoUntilStage=CompileUnit::Stage::Cleaned)
Link specified compile unit until specified stage.
void registerCIEs(CIERegistry &CIEs)
Register this context's CIEs with the linker-wide registry.
LinkContext(LinkingGlobalData &GlobalData, DWARFFile &File, uint64_t ObjFileIdx, StringMap< uint64_t > &ClangModules, std::atomic< size_t > &UniqueUnitID)
std::atomic< bool > HasNewInterconnectedCUs
Flag indicating that new inter-connected compilation units were discovered.
Error emitDebugFrame(const CIERegistry &CIEs)
Emit this context's .debug_frame section.
StringMap< uint64_t > & ClangModules
std::atomic< size_t > & UniqueUnitID
Counter for compile units ID.
Error link(TypeUnit *ArtificialTypeUnit)
Link compile units for this context.
StringMap< CIELocation > CIERegistry
Linker-wide registry for .debug_frame CIEs.
Error unloadInput()
Unload the input DWARFContext after scanning the input .debug_frame into FrameScan.
uint64_t ObjectFileIdx
Index of this object file in the link order (used for deterministic type DIE allocation).
std::atomic< bool > HasNewGlobalDependency
std::function< CompileUnit *(uint64_t)> getUnitForOffset
ModuleUnitListTy ModulesCompileUnits
Set of Compile Units for modules.
This structure is used to update strings offsets into .debug_line_str.
This structure is used to update strings offsets into .debug_str.
const StringEntry * String
This structure keeps fields which would be used for creating accelerator table.
dwarf::FormParams getFormParams() const
Returns FormParams used by section.
This structure is used to keep data of the concrete section.
raw_svector_ostream OS
Stream which stores data to the Contents.
void setSizesForSectionCreatedByAsmPrinter()
Some sections are emitted using AsmPrinter.