LLVM 20.0.0git
DWARFLinkerTypeUnit.h
Go to the documentation of this file.
1//===- DWARFLinkerTypeUnit.h ------------------------------------*- C++ -*-===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
9#ifndef LLVM_DWARFLINKER_PARALLEL_DWARFLINKERTYPEUNIT_H
10#define LLVM_DWARFLINKER_PARALLEL_DWARFLINKERTYPEUNIT_H
11
12#include "DWARFLinkerUnit.h"
13#include "llvm/CodeGen/DIE.h"
16
17namespace llvm {
18namespace dwarf_linker {
19namespace parallel {
20
21/// Type Unit is used to represent an artificial compilation unit
22/// which keeps all type information. This type information is referenced
23/// from other compilation units.
24class TypeUnit : public DwarfUnit {
25public:
27 std::optional<uint16_t> Language, dwarf::FormParams Format,
28 llvm::endianness Endianess);
29
30 /// Generates DIE tree based on information from TypesMap.
32
33 /// Emits resulting dwarf based on information from DIE tree.
34 Error finishCloningAndEmit(const Triple &TargetTriple);
35
36 /// Returns global type pool.
37 TypePool &getTypePool() { return Types; }
38
39 /// TypeUnitAccelInfo extends AccelInfo structure with type specific fileds.
40 /// We need these additional fields to decide whether OutDIE should have an
41 /// accelerator record or not. The TypeEntryBodyPtr can refer to the
42 /// declaration DIE and definition DIE corresponding to the type entry.
43 /// Only one of them would be used in final output. So if TypeUnitAccelInfo
44 /// refers OutDIE which does not match with TypeEntryBodyPtr->getFinalDie()
45 /// then such record should be skipped.
46 struct TypeUnitAccelInfo : public AccelInfo {
47 /// Pointer to the output DIE which owns this accelerator record.
48 DIE *OutDIE = nullptr;
49
50 /// Pointer to the type entry body.
52 };
53
54 /// Enumerates all accelerator records and call \p Handler for each.
55 void
56 forEachAcceleratorRecord(function_ref<void(AccelInfo &)> Handler) override {
57 AcceleratorRecords.forEach([&](TypeUnitAccelInfo &Info) {
58 // Check whether current record is for the final DIE.
59 assert(Info.TypeEntryBodyPtr != nullptr);
60
61 if (&Info.TypeEntryBodyPtr->getFinalDie() != Info.OutDIE)
62 return;
63
64 Info.OutOffset = Info.OutDIE->getOffset();
65 Handler(Info);
66 });
67 }
68
69 /// Returns index for the specified \p String inside .debug_str_offsets.
71 std::unique_lock<std::mutex> LockGuard(DebugStringIndexMapMutex);
72 return DebugStringIndexMap.getValueIndex(String);
73 }
74
75 /// Adds \p Info to the unit's accelerator records.
77 AcceleratorRecords.add(Info);
78 }
79
80private:
81 /// Type DIEs are partially created at clonning stage. They are organised
82 /// as a tree using type entries. This function links DIEs(corresponding
83 /// to the type entries) into the tree structure.
84 uint64_t finalizeTypeEntryRec(uint64_t OutOffset, DIE *OutDIE,
85 TypeEntry *Entry);
86
87 /// Prepares DIEs to be linked into the tree.
88 void prepareDataForTreeCreation();
89
90 /// Add specified \p Dir and \p Filename into the line table
91 /// of this type unit.
92 uint32_t addFileNameIntoLinetable(StringEntry *Dir, StringEntry *FileName);
93
94 std::pair<dwarf::Form, uint8_t> getScalarFormForValue(uint64_t Value) const;
95
96 uint8_t getSizeByAttrForm(dwarf::Form Form) const;
97
98 struct CmpStringEntryRef {
99 bool operator()(const StringEntry *LHS, const StringEntry *RHS) const {
100 return LHS->first() < RHS->first();
101 }
102 };
103 struct CmpDirIDStringEntryRef {
104 bool operator()(const std::pair<StringEntry *, uint64_t> &LHS,
105 const std::pair<StringEntry *, uint64_t> &RHS) const {
106 return LHS.second < RHS.second ||
107 (!(RHS.second < LHS.second) &&
108 LHS.first->first() < RHS.first->first());
109 }
110 };
111
112 /// The DW_AT_language of this unit.
113 std::optional<uint16_t> Language;
114
115 /// This unit line table.
116 DWARFDebugLine::LineTable LineTable;
117
118 /// Data members keeping file names for line table.
119 using DirectoriesMapTy = std::map<StringEntry *, size_t, CmpStringEntryRef>;
120 using FilenamesMapTy = std::map<std::pair<StringEntry *, uint64_t>, size_t,
121 CmpDirIDStringEntryRef>;
122
123 DirectoriesMapTy DirectoriesMap;
124 FilenamesMapTy FileNamesMap;
125
126 /// Type DIEs tree.
127 TypePool Types;
128
129 /// List of accelerator entries for this unit.
130 ArrayList<TypeUnitAccelInfo> AcceleratorRecords;
131
132 /// Guard for DebugStringIndexMap.
133 std::mutex DebugStringIndexMapMutex;
134};
135
136} // end of namespace parallel
137} // end of namespace dwarf_linker
138} // end of namespace llvm
139
140#endif // LLVM_DWARFLINKER_PARALLEL_DWARFLINKERTYPEUNIT_H
Analysis containing CSE Info
Definition: CSEInfo.cpp:27
Basic Register Allocator
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
Value * RHS
Value * LHS
Allocate memory in an ever growing pool, as if by bump-pointer.
Definition: Allocator.h:66
A structured debug information entry.
Definition: DIE.h:819
Lightweight error class with error context and mandatory checking.
Definition: Error.h:160
StringMapEntry - This is used to represent one value that is inserted into a StringMap.
Triple - Helper class for working with autoconf configuration names.
Definition: Triple.h:44
LLVM Value Representation.
Definition: Value.h:74
Base class for all Dwarf units(Compile unit/Type table unit).
IndexedValuesMap< const StringEntry * > DebugStringIndexMap
Maps a string into the index inside .debug_str_offsets section.
This class keeps data and services common for the whole linking process.
dwarf::FormParams Format
Format for sections.
Keeps cloned data for the type DIE.
Definition: TypePool.h:30
TypePool keeps type descriptors which contain partially cloned DIE correspinding to each type.
Definition: TypePool.h:111
Type Unit is used to represent an artificial compilation unit which keeps all type information.
void saveAcceleratorInfo(const TypeUnitAccelInfo &Info)
Adds Info to the unit's accelerator records.
TypePool & getTypePool()
Returns global type pool.
Error finishCloningAndEmit(const Triple &TargetTriple)
Emits resulting dwarf based on information from DIE tree.
uint64_t getDebugStrIndex(const StringEntry *String) override
Returns index for the specified String inside .debug_str_offsets.
void createDIETree(BumpPtrAllocator &Allocator)
Generates DIE tree based on information from TypesMap.
void forEachAcceleratorRecord(function_ref< void(AccelInfo &)> Handler) override
Enumerates all accelerator records and call Handler for each.
An efficient, type-erasing, non-owning reference to a callable.
constexpr char Language[]
Key for Kernel::Metadata::mLanguage.
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
endianness
Definition: bit.h:70
A helper struct providing information about the byte size of DW_FORM values that vary in size dependi...
Definition: Dwarf.h:1084
This structure keeps fields which would be used for creating accelerator table.
TypeUnitAccelInfo extends AccelInfo structure with type specific fileds.
DIE * OutDIE
Pointer to the output DIE which owns this accelerator record.
TypeEntryBody * TypeEntryBodyPtr
Pointer to the type entry body.