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)
101 if (std::optional<std::reference_wrapper<const Triple>> CurTriple =
103 GlobalEndianness = (*CurTriple).get().isLittleEndian()
107 std::optional<uint16_t> Language;
110 if (Context->InputDWARFFile.Dwarf ==
nullptr) {
111 Context->setOutputFormat(Context->getFormParams(), GlobalEndianness);
116 outs() <<
"DEBUG MAP OBJECT: " << Context->InputDWARFFile.FileName
119 for (
const std::unique_ptr<DWARFUnit> &OrigCU :
120 Context->InputDWARFFile.Dwarf->compile_units()) {
121 outs() <<
"Input compilation unit:";
125 OrigCU->getUnitDIE().dump(
outs(), 0, DumpOpts);
134 GlobalEndianness = Context->getEndianness();
136 std::max(GlobalFormat.
AddrSize, Context->getFormParams().AddrSize);
138 Context->setOutputFormat(Context->getFormParams(), GlobalEndianness);
143 for (
const std::unique_ptr<DWARFUnit> &OrigCU :
144 Context->InputDWARFFile.Dwarf->compile_units()) {
145 DWARFDie UnitDie = OrigCU->getUnitDIE();
148 if (std::optional<DWARFFormValue> Val =
149 UnitDie.
find(dwarf::DW_AT_language)) {
159 if (std::optional<std::reference_wrapper<const Triple>> TargetTriple =
161 GlobalFormat.
AddrSize = (*TargetTriple).get().isArch32Bit() ? 4 : 8;
168 if (!
GlobalData.Options.NoODR && Language.has_value()) {
188 GlobalData.error(std::move(Err), Context->InputDWARFFile.FileName);
189 if (
Error Err = Context->unloadInput())
190 GlobalData.error(std::move(Err), Context->InputDWARFFile.FileName);
198 GlobalData.error(std::move(Err), Context->InputDWARFFile.FileName);
199 if (
Error Err = Context->unloadInput())
200 GlobalData.error(std::move(Err), Context->InputDWARFFile.FileName);
210 GlobalData.Options.ParseableSwiftInterfaces) {
213 Context->ModulesCompileUnits)
214 ModuleUnit.
Unit->mergeSwiftInterfaces(*SwiftInterfaces);
215 for (std::unique_ptr<CompileUnit> &
CU : Context->CompileUnits)
216 CU->mergeSwiftInterfaces(*SwiftInterfaces);
222 if (!
GlobalData.getOptions().UpdateIndexTablesOnly) {
225 if (Context->FrameScan)
226 Context->registerCIEs(CIEs);
230 if (!Context->FrameScan)
233 if (
Error Err = Context->emitDebugFrame(CIEs))
234 GlobalData.error(std::move(Err), Context->InputDWARFFile.FileName);
243 ->Children.empty()) {
265 if (
GlobalData.getOptions().InputVerificationHandler)
266 GlobalData.getOptions().InputVerificationHandler(File, OS.
str());
271 if (
GlobalData.getOptions().TargetDWARFVersion == 0)
273 "target DWARF version is not set");
278 "set number of threads to 1 to make --verbose to work properly.",
"");
282 if (
GlobalData.getOptions().UpdateIndexTablesOnly &&
297 CUDie.
find({dwarf::DW_AT_dwo_id, dwarf::DW_AT_GNU_dwo_id}));
306 if (ObjectPrefixMap.empty())
310 for (
const auto &Entry : ObjectPrefixMap)
313 return p.str().str();
319 CUDie.
find({dwarf::DW_AT_dwo_name, dwarf::DW_AT_GNU_dwo_name}),
"");
325 PCMFile =
remapPath(PCMFile, *ObjectPrefixMap);
331 const DWARFDie &CUDie, std::string &PCMFile,
unsigned Indent,
bool Quiet) {
333 return std::make_pair(
false,
false);
341 GlobalData.warn(
"anonymous module skeleton CU for " + PCMFile +
".",
343 return std::make_pair(
true,
true);
348 outs() <<
"Found clang module reference " << PCMFile;
356 if (!
Quiet &&
GlobalData.getOptions().Verbose && (Cached->second != DwoId))
358 Twine(
"hash mismatch: this object file was built against a "
359 "different version of the module ") +
363 outs() <<
" [cached].\n";
364 return std::make_pair(
true,
true);
367 return std::make_pair(
true,
false);
379 std::string PCMFile =
381 std::pair<bool, bool> IsClangModuleRef =
384 if (!IsClangModuleRef.first)
387 if (IsClangModuleRef.second)
420 if (Loader ==
nullptr) {
421 GlobalData.error(
"cann't load clang module: loader is not specified.",
430 std::unique_ptr<CompileUnit> Unit;
431 for (
const auto &
CU : ErrOrObj->Dwarf->compile_units()) {
434 auto ChildCUDie =
CU->getUnitDIE();
441 ": Clang modules are expected to have exactly 1 compile unit.\n");
449 if (PCMDwoId != DwoId) {
452 Twine(
"hash mismatch: this object file was built against a "
453 "different version of the module ") +
461 if (!ChildCUDie.hasChildren())
465 Unit = std::make_unique<CompileUnit>(
503 if (!
GlobalData.getOptions().UpdateIndexTablesOnly &&
506 outs() <<
"No valid relocations found. Skipping.\n";
514 for (
const auto &OrigCU :
InputDWARFFile.Dwarf->compile_units()) {
516 auto CUDie = OrigCU->getUnitDIE();
517 std::string PCMFile =
522 if (!CUDie ||
GlobalData.getOptions().UpdateIndexTablesOnly ||
524 CompileUnits.emplace_back(std::make_unique<CompileUnit>(
553 if (
CU->isInterconnectedCU()) {
554 CU->maybeResetToLoadedStage();
582 if (
CU->isInterconnectedCU() &&
612 if (
GlobalData.getOptions().UpdateIndexTablesOnly) {
629 if (
CU.getStage() >= DoUntilStage)
632 switch (
CU.getStage()) {
636 if (!
CU.loadInputDIEs()) {
641 CU.analyzeDWARFStructure();
649 CU.getOrigUnit().getUnitDIE(),
nullptr,
663 "Flag indicating new inter-connections is not set");
672 if (
CU.updateDependenciesCompleteness())
677 return CU.updateDependenciesCompleteness();
679 return std::move(Err);
687 CU.verifyDependencies();
693 return std::move(Err);
700 if (
CU.isClangModule() ||
701 GlobalData.getOptions().UpdateIndexTablesOnly ||
702 CU.getContaingFile().Addresses->hasValidRelocs()) {
705 return std::move(Err);
713 CU.updateDieRefPatchesWithClonedOffsets();
719 CU.cleanupDataAfterClonning();
734 CU.error(std::move(Err));
735 CU.cleanupDataAfterClonning();
741 if (!
GlobalData.getTargetTriple().has_value())
763 if (
GlobalData.getOptions().UpdateIndexTablesOnly)
765 if (!
GlobalData.getTargetTriple().has_value())
776 if (OrigFrameData.
empty())
779 auto Scan = std::make_unique<FrameScanResult>();
780 Scan->FrameData = OrigFrameData;
784 for (std::unique_ptr<CompileUnit> &Unit :
CompileUnits) {
785 for (
auto CurRange : Unit->getFunctionRanges())
786 AllUnitsRanges.
insert(CurRange.Range, CurRange.Value);
792 const unsigned SrcAddrSize = Scan->AddressSize;
795 constexpr unsigned CIEPointerSize = 4;
801 while (
Data.isValidOffset(InputOffset)) {
804 if (InitialLength == 0xFFFFFFFF)
807 "Dwarf64 bits not supported"));
812 if (InitialLength > FrameBytes.
size() - InputOffset)
816 "Truncated .debug_frame entry."));
819 if (CIEId == 0xFFFFFFFF) {
822 LocalCIEs[EntryOffset] = CIEData;
824 InputOffset += InitialLength - 4;
834 std::optional<AddressRangeValuePair>
Range =
838 InputOffset = EntryOffset + InitialLength + 4;
848 "Inconsistent debug_frame content. Dropping."));
853 if (InitialLength < CIEPointerSize + SrcAddrSize)
856 "Truncated .debug_frame FDE."));
860 if (AddedCIEs.
insert(CIEId).second)
861 Scan->CIEs.push_back(CIEData);
863 unsigned FDERemainingBytes = InitialLength - (CIEPointerSize + SrcAddrSize);
864 Scan->FDEs.push_back({CIEData,
Loc +
Range->Value,
865 FrameBytes.
substr(InputOffset, FDERemainingBytes)});
866 InputOffset += FDERemainingBytes;
880 auto [It, Inserted] =
883 FrameScan->OwnedCIEs.push_back(CIEBytes);
884 NextLocalOffset +=
static_cast<uint32_t>(CIEBytes.
size());
896 OutSection.
OS << CIEBytes;
899 const unsigned SrcAddrSize =
FrameScan->AddressSize;
903 assert(It != CIEs.
end() &&
"CIE missing from registry");
905 const uint32_t CIELocalOffset = It->second.LocalOffset;
914 if (FDEPos >
FP.getDwarfMaxOffset())
949 Section.emitIntVal(FDEBytes.
size() + 4 + AddrSize, 4);
950 Section.emitIntVal(CIEOffset, 4);
951 Section.emitIntVal(
Address, AddrSize);
952 Section.OS.write(FDEBytes.
data(), FDEBytes.
size());
956 if (!
GlobalData.getTargetTriple().has_value())
989 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts) {
990 uint64_t AllDebugInfoSectionsSize = 0;
992 for (std::unique_ptr<CompileUnit> &
CU : Context->CompileUnits)
993 if (std::optional<SectionDescriptor *>
DebugInfo =
995 AllDebugInfoSectionsSize += (*DebugInfo)->getContents().size();
997 auto &
Size = SizeByObject[Context->InputDWARFFile.FileName];
998 Size.Input = Context->OriginalDebugInfoSize;
999 Size.Output = AllDebugInfoSectionsSize;
1003 std::vector<std::pair<StringRef, DebugInfoSize>> Sorted;
1004 for (
auto &E : SizeByObject)
1005 Sorted.emplace_back(E.first(), E.second);
1006 llvm::sort(Sorted, [](
auto &LHS,
auto &RHS) {
1007 return LHS.second.Output > RHS.second.Output;
1010 auto ComputePercentange = [](int64_t
Input, int64_t Output) ->
float {
1011 const float Difference = Output -
Input;
1012 const float Sum =
Input + Output;
1015 return (Difference / (Sum / 2));
1018 int64_t InputTotal = 0;
1019 int64_t OutputTotal = 0;
1020 const char *FormatStr =
"{0,-45} {1,10}b {2,10}b {3,8:P}\n";
1023 outs() <<
".debug_info section size (in bytes)\n";
1024 outs() <<
"----------------------------------------------------------------"
1025 "---------------\n";
1026 outs() <<
"Filename Object "
1028 outs() <<
"----------------------------------------------------------------"
1029 "---------------\n";
1032 for (
auto &E : Sorted) {
1033 InputTotal += E.second.Input;
1034 OutputTotal += E.second.Output;
1037 E.second.Output, ComputePercentange(E.second.Input, E.second.Output));
1040 outs() <<
"----------------------------------------------------------------"
1041 "---------------\n";
1043 ComputePercentange(InputTotal, OutputTotal));
1044 outs() <<
"----------------------------------------------------------------"
1045 "---------------\n\n";
1055 size_t CurDebugStrIndex = 1;
1058 size_t CurDebugLineStrIndex = 0;
1059 uint64_t CurDebugLineStrOffset = 0;
1068 assert(Entry !=
nullptr);
1070 if (!Entry->isIndexed()) {
1071 Entry->Offset = CurDebugStrOffset;
1072 CurDebugStrOffset += Entry->String.size() + 1;
1073 Entry->Index = CurDebugStrIndex++;
1079 assert(Entry !=
nullptr);
1081 if (!Entry->isIndexed()) {
1082 Entry->Offset = CurDebugLineStrOffset;
1083 CurDebugLineStrOffset += Entry->String.size() + 1;
1084 Entry->Index = CurDebugLineStrIndex++;
1092 std::array<uint64_t, SectionKindsNum> SectionSizesAccumulator = {0};
1109 OutSection.ListDebugStrPatch.forEach([&](
DebugStrPatch &Patch) {
1119 StringHandler(
DebugStr, Info.String);
1125 OutSection.ListDebugStrPatch.forEach([&](
DebugStrPatch &Patch) {
1134 if (Patch.Die ==
nullptr)
1138 if (&
TypeEntry->getFinalDie() != Patch.Die)
1144 OutSection.ListDebugTypeLineStrPatch.forEach(
1146 if (Patch.Die ==
nullptr)
1150 if (&
TypeEntry->getFinalDie() != Patch.Die)
1166 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts)
1169 SectionsSetHandler(*ModuleUnit.
Unit);
1172 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts) {
1174 SectionsSetHandler(*Context);
1177 for (std::unique_ptr<CompileUnit> &
CU : Context->CompileUnits)
1179 SectionsSetHandler(*
CU);
1189 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts)
1192 UnitHandler(ModuleUnit.
Unit.get());
1195 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts)
1196 for (std::unique_ptr<CompileUnit> &
CU : Context->CompileUnits)
1198 UnitHandler(
CU.get());
1204 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts)
1207 UnitHandler(ModuleUnit.
Unit.get());
1210 for (
const std::unique_ptr<LinkContext> &Context :
ObjectContexts)
1211 for (std::unique_ptr<CompileUnit> &
CU : Context->CompileUnits)
1213 UnitHandler(
CU.get());
1273 uint64_t DebugLineStrNextOffset = 0;
1278 .emitInplaceString(
"");
1279 DebugStrNextOffset++;
1292 if (StringToEmit->
Offset >= DebugStrNextOffset) {
1293 DebugStrNextOffset =
1297 .emitInplaceString(StringToEmit->
String);
1308 if (StringToEmit->
Offset >= DebugLineStrNextOffset) {
1309 DebugLineStrNextOffset =
1313 .emitInplaceString(StringToEmit->
String);
1328 uint64_t OutOffset = Info.OutOffset;
1329 switch (Info.Type) {
1359 Info.QualifiedNameHash);
1373 if (
Error Err =
Emitter.init(TargetTriple,
"__DWARF")) {
1394 if (
Error Err =
Emitter.init(TargetTriple,
"__DWARF")) {
1415 if (
Error Err =
Emitter.init(TargetTriple,
"__DWARF")) {
1436 if (
Error Err =
Emitter.init(TargetTriple,
"__DWARF")) {
1451 std::unique_ptr<DWARF5AccelTable>
DebugNames;
1459 bool HasRecords =
false;
1462 DebugNames = std::make_unique<DWARF5AccelTable>();
1465 switch (Info.Type) {
1470 Info.OutOffset, Info.ParentOffset, Info.Tag,
1472 CU->getTag() == dwarf::DW_TAG_type_unit);
1481 CompUnits.push_back(
1484 CUidToIdx[
CU->getUniqueID()] = Id++;
1496 if (
Error Err =
Emitter.init(TargetTriple,
"__DWARF")) {
1519 Sections.
forEach([&](std::shared_ptr<SectionDescriptor> OutSection) {
1527 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.