1 //===-- DWARFDebugInfoEntry.h -----------------------------------*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 #ifndef SymbolFileDWARF_DWARFDebugInfoEntry_h_
11 #define SymbolFileDWARF_DWARFDebugInfoEntry_h_
13 #include "SymbolFileDWARF.h"
14 #include "llvm/ADT/SmallVector.h"
16 #include "DWARFAbbreviationDeclaration.h"
17 #include "DWARFDebugAbbrev.h"
18 #include "DWARFDebugRanges.h"
23 typedef std::map<const DWARFDebugInfoEntry *, dw_addr_t> DIEToAddressMap;
24 typedef DIEToAddressMap::iterator DIEToAddressMapIter;
25 typedef DIEToAddressMap::const_iterator DIEToAddressMapConstIter;
27 typedef std::map<dw_addr_t, const DWARFDebugInfoEntry *> AddressToDIEMap;
28 typedef AddressToDIEMap::iterator AddressToDIEMapIter;
29 typedef AddressToDIEMap::const_iterator AddressToDIEMapConstIter;
31 typedef std::map<dw_offset_t, dw_offset_t> DIEToDIEMap;
32 typedef DIEToDIEMap::iterator DIEToDIEMapIter;
33 typedef DIEToDIEMap::const_iterator DIEToDIEMapConstIter;
35 typedef std::map<uint32_t, const DWARFDebugInfoEntry *> UInt32ToDIEMap;
36 typedef UInt32ToDIEMap::iterator UInt32ToDIEMapIter;
37 typedef UInt32ToDIEMap::const_iterator UInt32ToDIEMapConstIter;
39 typedef std::multimap<uint32_t, const DWARFDebugInfoEntry *> UInt32ToDIEMMap;
40 typedef UInt32ToDIEMMap::iterator UInt32ToDIEMMapIter;
41 typedef UInt32ToDIEMMap::const_iterator UInt32ToDIEMMapConstIter;
43 class DWARFDeclContext;
45 #define DIE_SIBLING_IDX_BITSIZE 31
46 #define DIE_ABBR_IDX_BITSIZE 15
48 class DWARFDebugInfoEntry {
50 typedef std::vector<DWARFDebugInfoEntry> collection;
51 typedef collection::iterator iterator;
52 typedef collection::const_iterator const_iterator;
54 typedef std::vector<dw_offset_t> offset_collection;
55 typedef offset_collection::iterator offset_collection_iterator;
56 typedef offset_collection::const_iterator offset_collection_const_iterator;
59 : m_offset(DW_INVALID_OFFSET), m_parent_idx(0), m_sibling_idx(0),
60 m_empty_children(false), m_abbr_idx(0), m_has_children(false),
63 explicit operator bool() const { return m_offset != DW_INVALID_OFFSET; }
64 bool operator==(const DWARFDebugInfoEntry &rhs) const;
65 bool operator!=(const DWARFDebugInfoEntry &rhs) const;
67 void BuildAddressRangeTable(SymbolFileDWARF *dwarf2Data,
69 DWARFDebugAranges *debug_aranges) const;
71 void BuildFunctionAddressRangeTable(SymbolFileDWARF *dwarf2Data,
73 DWARFDebugAranges *debug_aranges) const;
75 bool FastExtract(const lldb_private::DWARFDataExtractor &debug_info_data,
77 const DWARFFormValue::FixedFormSizes &fixed_form_sizes,
78 lldb::offset_t *offset_ptr);
80 bool Extract(SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
81 lldb::offset_t *offset_ptr);
83 bool LookupAddress(const dw_addr_t address, SymbolFileDWARF *dwarf2Data,
85 DWARFDebugInfoEntry **function_die,
86 DWARFDebugInfoEntry **block_die);
88 size_t GetAttributes(const DWARFUnit *cu,
89 DWARFFormValue::FixedFormSizes fixed_form_sizes,
90 DWARFAttributes &attrs,
91 uint32_t curr_depth = 0)
92 const; // "curr_depth" for internal use only, don't set this yourself!!!
95 GetAttributeValue(SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
96 const dw_attr_t attr, DWARFFormValue &formValue,
97 dw_offset_t *end_attr_offset_ptr = nullptr,
98 bool check_specification_or_abstract_origin = false) const;
100 const char *GetAttributeValueAsString(
101 SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
102 const dw_attr_t attr, const char *fail_value,
103 bool check_specification_or_abstract_origin = false) const;
105 uint64_t GetAttributeValueAsUnsigned(
106 SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
107 const dw_attr_t attr, uint64_t fail_value,
108 bool check_specification_or_abstract_origin = false) const;
110 uint64_t GetAttributeValueAsReference(
111 SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
112 const dw_attr_t attr, uint64_t fail_value,
113 bool check_specification_or_abstract_origin = false) const;
115 int64_t GetAttributeValueAsSigned(
116 SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
117 const dw_attr_t attr, int64_t fail_value,
118 bool check_specification_or_abstract_origin = false) const;
120 uint64_t GetAttributeValueAsAddress(
121 SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
122 const dw_attr_t attr, uint64_t fail_value,
123 bool check_specification_or_abstract_origin = false) const;
126 GetAttributeHighPC(SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
127 dw_addr_t lo_pc, uint64_t fail_value,
128 bool check_specification_or_abstract_origin = false) const;
130 bool GetAttributeAddressRange(
131 SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu, dw_addr_t &lo_pc,
132 dw_addr_t &hi_pc, uint64_t fail_value,
133 bool check_specification_or_abstract_origin = false) const;
135 size_t GetAttributeAddressRanges(
136 SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
137 DWARFRangeList &ranges, bool check_hi_lo_pc,
138 bool check_specification_or_abstract_origin = false) const;
140 const char *GetName(SymbolFileDWARF *dwarf2Data,
141 const DWARFUnit *cu) const;
143 const char *GetMangledName(SymbolFileDWARF *dwarf2Data,
145 bool substitute_name_allowed = true) const;
147 const char *GetPubname(SymbolFileDWARF *dwarf2Data,
148 const DWARFUnit *cu) const;
150 static bool GetName(SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
151 const dw_offset_t die_offset, lldb_private::Stream &s);
153 static bool AppendTypeName(SymbolFileDWARF *dwarf2Data,
155 const dw_offset_t die_offset,
156 lldb_private::Stream &s);
158 const char *GetQualifiedName(SymbolFileDWARF *dwarf2Data,
160 std::string &storage) const;
162 const char *GetQualifiedName(SymbolFileDWARF *dwarf2Data,
164 const DWARFAttributes &attributes,
165 std::string &storage) const;
167 static bool OffsetLessThan(const DWARFDebugInfoEntry &a,
168 const DWARFDebugInfoEntry &b);
170 void Dump(SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
171 lldb_private::Stream &s, uint32_t recurse_depth) const;
173 void DumpAncestry(SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
174 const DWARFDebugInfoEntry *oldest, lldb_private::Stream &s,
175 uint32_t recurse_depth) const;
178 DumpAttribute(SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
179 const lldb_private::DWARFDataExtractor &debug_info_data,
180 lldb::offset_t *offset_ptr, lldb_private::Stream &s,
181 dw_attr_t attr, dw_form_t form);
182 // This one dumps the comp unit name, objfile name and die offset for this die
184 void DumpLocation(SymbolFileDWARF *dwarf2Data, DWARFUnit *cu,
185 lldb_private::Stream &s) const;
188 GetDIENamesAndRanges(SymbolFileDWARF *dwarf2Data, const DWARFUnit *cu,
189 const char *&name, const char *&mangled,
190 DWARFRangeList &rangeList, int &decl_file,
191 int &decl_line, int &decl_column, int &call_file,
192 int &call_line, int &call_column,
193 lldb_private::DWARFExpression *frame_base = NULL) const;
195 const DWARFAbbreviationDeclaration *
196 GetAbbreviationDeclarationPtr(SymbolFileDWARF *dwarf2Data,
198 lldb::offset_t &offset) const;
200 dw_tag_t Tag() const { return m_tag; }
202 bool IsNULL() const { return m_abbr_idx == 0; }
204 dw_offset_t GetOffset() const { return m_offset; }
206 bool HasChildren() const { return m_has_children; }
208 void SetHasChildren(bool b) { m_has_children = b; }
210 // We know we are kept in a vector of contiguous entries, so we know
211 // our parent will be some index behind "this".
212 DWARFDebugInfoEntry *GetParent() {
213 return m_parent_idx > 0 ? this - m_parent_idx : NULL;
215 const DWARFDebugInfoEntry *GetParent() const {
216 return m_parent_idx > 0 ? this - m_parent_idx : NULL;
218 // We know we are kept in a vector of contiguous entries, so we know
219 // our sibling will be some index after "this".
220 DWARFDebugInfoEntry *GetSibling() {
221 return m_sibling_idx > 0 ? this + m_sibling_idx : NULL;
223 const DWARFDebugInfoEntry *GetSibling() const {
224 return m_sibling_idx > 0 ? this + m_sibling_idx : NULL;
226 // We know we are kept in a vector of contiguous entries, so we know
227 // we don't need to store our child pointer, if we have a child it will
228 // be the next entry in the list...
229 DWARFDebugInfoEntry *GetFirstChild() {
230 return (HasChildren() && !m_empty_children) ? this + 1 : NULL;
232 const DWARFDebugInfoEntry *GetFirstChild() const {
233 return (HasChildren() && !m_empty_children) ? this + 1 : NULL;
236 void GetDeclContextDIEs(DWARFUnit *cu,
237 DWARFDIECollection &decl_context_dies) const;
239 void GetDWARFDeclContext(SymbolFileDWARF *dwarf2Data, DWARFUnit *cu,
240 DWARFDeclContext &dwarf_decl_ctx) const;
242 bool MatchesDWARFDeclContext(SymbolFileDWARF *dwarf2Data,
244 const DWARFDeclContext &dwarf_decl_ctx) const;
246 DWARFDIE GetParentDeclContextDIE(SymbolFileDWARF *dwarf2Data,
247 DWARFUnit *cu) const;
248 DWARFDIE GetParentDeclContextDIE(SymbolFileDWARF *dwarf2Data,
250 const DWARFAttributes &attributes) const;
252 void SetParent(DWARFDebugInfoEntry *parent) {
254 // We know we are kept in a vector of contiguous entries, so we know
255 // our parent will be some index behind "this".
256 m_parent_idx = this - parent;
260 void SetSibling(DWARFDebugInfoEntry *sibling) {
262 // We know we are kept in a vector of contiguous entries, so we know
263 // our sibling will be some index after "this".
264 m_sibling_idx = sibling - this;
265 sibling->SetParent(GetParent());
270 void SetSiblingIndex(uint32_t idx) { m_sibling_idx = idx; }
272 void SetParentIndex(uint32_t idx) { m_parent_idx = idx; }
274 bool GetEmptyChildren() const { return m_empty_children; }
276 void SetEmptyChildren(bool b) { m_empty_children = b; }
279 DumpDIECollection(lldb_private::Stream &strm,
280 DWARFDebugInfoEntry::collection &die_collection);
284 m_offset; // Offset within the .debug_info of the start of this entry
285 uint32_t m_parent_idx; // How many to subtract from "this" to get the parent.
286 // If zero this die has no parent
287 uint32_t m_sibling_idx : 31, // How many to add to "this" to get the sibling.
288 m_empty_children : 1; // If a DIE says it had children, yet it just
289 // contained a NULL tag, this will be set.
290 uint32_t m_abbr_idx : DIE_ABBR_IDX_BITSIZE,
291 m_has_children : 1, // Set to 1 if this DIE has children
292 m_tag : 16; // A copy of the DW_TAG value so we don't
293 // have to go through the compile unit
297 #endif // SymbolFileDWARF_DWARFDebugInfoEntry_h_