1 //===-- llvm/BinaryFormat/Dwarf.cpp - Dwarf Framework ------------*- C++-*-===//
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
7 //===----------------------------------------------------------------------===//
9 // This file contains support for generic dwarf information.
11 //===----------------------------------------------------------------------===//
13 #include "llvm/BinaryFormat/Dwarf.h"
14 #include "llvm/ADT/StringSwitch.h"
15 #include "llvm/ADT/Triple.h"
16 #include "llvm/Support/ErrorHandling.h"
19 using namespace dwarf
;
21 StringRef
llvm::dwarf::TagString(unsigned Tag
) {
25 #define HANDLE_DW_TAG(ID, NAME, VERSION, VENDOR, KIND) \
27 return "DW_TAG_" #NAME;
28 #include "llvm/BinaryFormat/Dwarf.def"
32 unsigned llvm::dwarf::getTag(StringRef TagString
) {
33 return StringSwitch
<unsigned>(TagString
)
34 #define HANDLE_DW_TAG(ID, NAME, VERSION, VENDOR, KIND) \
35 .Case("DW_TAG_" #NAME, DW_TAG_##NAME)
36 #include "llvm/BinaryFormat/Dwarf.def"
37 .Default(DW_TAG_invalid
);
40 unsigned llvm::dwarf::TagVersion(dwarf::Tag Tag
) {
44 #define HANDLE_DW_TAG(ID, NAME, VERSION, VENDOR, KIND) \
47 #include "llvm/BinaryFormat/Dwarf.def"
51 unsigned llvm::dwarf::TagVendor(dwarf::Tag Tag
) {
55 #define HANDLE_DW_TAG(ID, NAME, VERSION, VENDOR, KIND) \
57 return DWARF_VENDOR_##VENDOR;
58 #include "llvm/BinaryFormat/Dwarf.def"
62 StringRef
llvm::dwarf::ChildrenString(unsigned Children
) {
65 return "DW_CHILDREN_no";
67 return "DW_CHILDREN_yes";
72 StringRef
llvm::dwarf::AttributeString(unsigned Attribute
) {
76 #define HANDLE_DW_AT(ID, NAME, VERSION, VENDOR) \
78 return "DW_AT_" #NAME;
79 #include "llvm/BinaryFormat/Dwarf.def"
83 unsigned llvm::dwarf::AttributeVersion(dwarf::Attribute Attribute
) {
87 #define HANDLE_DW_AT(ID, NAME, VERSION, VENDOR) \
90 #include "llvm/BinaryFormat/Dwarf.def"
94 unsigned llvm::dwarf::AttributeVendor(dwarf::Attribute Attribute
) {
98 #define HANDLE_DW_AT(ID, NAME, VERSION, VENDOR) \
100 return DWARF_VENDOR_##VENDOR;
101 #include "llvm/BinaryFormat/Dwarf.def"
105 StringRef
llvm::dwarf::FormEncodingString(unsigned Encoding
) {
109 #define HANDLE_DW_FORM(ID, NAME, VERSION, VENDOR) \
110 case DW_FORM_##NAME: \
111 return "DW_FORM_" #NAME;
112 #include "llvm/BinaryFormat/Dwarf.def"
116 unsigned llvm::dwarf::FormVersion(dwarf::Form Form
) {
120 #define HANDLE_DW_FORM(ID, NAME, VERSION, VENDOR) \
121 case DW_FORM_##NAME: \
123 #include "llvm/BinaryFormat/Dwarf.def"
127 unsigned llvm::dwarf::FormVendor(dwarf::Form Form
) {
131 #define HANDLE_DW_FORM(ID, NAME, VERSION, VENDOR) \
132 case DW_FORM_##NAME: \
133 return DWARF_VENDOR_##VENDOR;
134 #include "llvm/BinaryFormat/Dwarf.def"
138 StringRef
llvm::dwarf::OperationEncodingString(unsigned Encoding
) {
142 #define HANDLE_DW_OP(ID, NAME, VERSION, VENDOR) \
144 return "DW_OP_" #NAME;
145 #include "llvm/BinaryFormat/Dwarf.def"
146 case DW_OP_LLVM_convert
:
147 return "DW_OP_LLVM_convert";
148 case DW_OP_LLVM_fragment
:
149 return "DW_OP_LLVM_fragment";
150 case DW_OP_LLVM_tag_offset
:
151 return "DW_OP_LLVM_tag_offset";
155 unsigned llvm::dwarf::getOperationEncoding(StringRef OperationEncodingString
) {
156 return StringSwitch
<unsigned>(OperationEncodingString
)
157 #define HANDLE_DW_OP(ID, NAME, VERSION, VENDOR) \
158 .Case("DW_OP_" #NAME, DW_OP_##NAME)
159 #include "llvm/BinaryFormat/Dwarf.def"
160 .Case("DW_OP_LLVM_convert", DW_OP_LLVM_convert
)
161 .Case("DW_OP_LLVM_fragment", DW_OP_LLVM_fragment
)
162 .Case("DW_OP_LLVM_tag_offset", DW_OP_LLVM_tag_offset
)
166 unsigned llvm::dwarf::OperationVersion(dwarf::LocationAtom Op
) {
170 #define HANDLE_DW_OP(ID, NAME, VERSION, VENDOR) \
173 #include "llvm/BinaryFormat/Dwarf.def"
177 unsigned llvm::dwarf::OperationVendor(dwarf::LocationAtom Op
) {
181 #define HANDLE_DW_OP(ID, NAME, VERSION, VENDOR) \
183 return DWARF_VENDOR_##VENDOR;
184 #include "llvm/BinaryFormat/Dwarf.def"
188 StringRef
llvm::dwarf::AttributeEncodingString(unsigned Encoding
) {
192 #define HANDLE_DW_ATE(ID, NAME, VERSION, VENDOR) \
193 case DW_ATE_##NAME: \
194 return "DW_ATE_" #NAME;
195 #include "llvm/BinaryFormat/Dwarf.def"
199 unsigned llvm::dwarf::getAttributeEncoding(StringRef EncodingString
) {
200 return StringSwitch
<unsigned>(EncodingString
)
201 #define HANDLE_DW_ATE(ID, NAME, VERSION, VENDOR) \
202 .Case("DW_ATE_" #NAME, DW_ATE_##NAME)
203 #include "llvm/BinaryFormat/Dwarf.def"
207 unsigned llvm::dwarf::AttributeEncodingVersion(dwarf::TypeKind ATE
) {
211 #define HANDLE_DW_ATE(ID, NAME, VERSION, VENDOR) \
212 case DW_ATE_##NAME: \
214 #include "llvm/BinaryFormat/Dwarf.def"
218 unsigned llvm::dwarf::AttributeEncodingVendor(dwarf::TypeKind ATE
) {
222 #define HANDLE_DW_ATE(ID, NAME, VERSION, VENDOR) \
223 case DW_ATE_##NAME: \
224 return DWARF_VENDOR_##VENDOR;
225 #include "llvm/BinaryFormat/Dwarf.def"
229 StringRef
llvm::dwarf::DecimalSignString(unsigned Sign
) {
232 return "DW_DS_unsigned";
233 case DW_DS_leading_overpunch
:
234 return "DW_DS_leading_overpunch";
235 case DW_DS_trailing_overpunch
:
236 return "DW_DS_trailing_overpunch";
237 case DW_DS_leading_separate
:
238 return "DW_DS_leading_separate";
239 case DW_DS_trailing_separate
:
240 return "DW_DS_trailing_separate";
245 StringRef
llvm::dwarf::EndianityString(unsigned Endian
) {
248 return "DW_END_default";
252 return "DW_END_little";
254 return "DW_END_lo_user";
256 return "DW_END_hi_user";
261 StringRef
llvm::dwarf::AccessibilityString(unsigned Access
) {
263 // Accessibility codes
264 case DW_ACCESS_public
:
265 return "DW_ACCESS_public";
266 case DW_ACCESS_protected
:
267 return "DW_ACCESS_protected";
268 case DW_ACCESS_private
:
269 return "DW_ACCESS_private";
274 StringRef
llvm::dwarf::VisibilityString(unsigned Visibility
) {
275 switch (Visibility
) {
277 return "DW_VIS_local";
278 case DW_VIS_exported
:
279 return "DW_VIS_exported";
280 case DW_VIS_qualified
:
281 return "DW_VIS_qualified";
286 StringRef
llvm::dwarf::VirtualityString(unsigned Virtuality
) {
287 switch (Virtuality
) {
290 #define HANDLE_DW_VIRTUALITY(ID, NAME) \
291 case DW_VIRTUALITY_##NAME: \
292 return "DW_VIRTUALITY_" #NAME;
293 #include "llvm/BinaryFormat/Dwarf.def"
297 unsigned llvm::dwarf::getVirtuality(StringRef VirtualityString
) {
298 return StringSwitch
<unsigned>(VirtualityString
)
299 #define HANDLE_DW_VIRTUALITY(ID, NAME) \
300 .Case("DW_VIRTUALITY_" #NAME, DW_VIRTUALITY_##NAME)
301 #include "llvm/BinaryFormat/Dwarf.def"
302 .Default(DW_VIRTUALITY_invalid
);
305 StringRef
llvm::dwarf::LanguageString(unsigned Language
) {
309 #define HANDLE_DW_LANG(ID, NAME, LOWER_BOUND, VERSION, VENDOR) \
310 case DW_LANG_##NAME: \
311 return "DW_LANG_" #NAME;
312 #include "llvm/BinaryFormat/Dwarf.def"
316 unsigned llvm::dwarf::getLanguage(StringRef LanguageString
) {
317 return StringSwitch
<unsigned>(LanguageString
)
318 #define HANDLE_DW_LANG(ID, NAME, LOWER_BOUND, VERSION, VENDOR) \
319 .Case("DW_LANG_" #NAME, DW_LANG_##NAME)
320 #include "llvm/BinaryFormat/Dwarf.def"
324 unsigned llvm::dwarf::LanguageVersion(dwarf::SourceLanguage Lang
) {
328 #define HANDLE_DW_LANG(ID, NAME, LOWER_BOUND, VERSION, VENDOR) \
329 case DW_LANG_##NAME: \
331 #include "llvm/BinaryFormat/Dwarf.def"
335 unsigned llvm::dwarf::LanguageVendor(dwarf::SourceLanguage Lang
) {
339 #define HANDLE_DW_LANG(ID, NAME, LOWER_BOUND, VERSION, VENDOR) \
340 case DW_LANG_##NAME: \
341 return DWARF_VENDOR_##VENDOR;
342 #include "llvm/BinaryFormat/Dwarf.def"
346 Optional
<unsigned> llvm::dwarf::LanguageLowerBound(dwarf::SourceLanguage Lang
) {
350 #define HANDLE_DW_LANG(ID, NAME, LOWER_BOUND, VERSION, VENDOR) \
351 case DW_LANG_##NAME: \
353 #include "llvm/BinaryFormat/Dwarf.def"
357 StringRef
llvm::dwarf::CaseString(unsigned Case
) {
359 case DW_ID_case_sensitive
:
360 return "DW_ID_case_sensitive";
362 return "DW_ID_up_case";
363 case DW_ID_down_case
:
364 return "DW_ID_down_case";
365 case DW_ID_case_insensitive
:
366 return "DW_ID_case_insensitive";
371 StringRef
llvm::dwarf::ConventionString(unsigned CC
) {
375 #define HANDLE_DW_CC(ID, NAME) \
377 return "DW_CC_" #NAME;
378 #include "llvm/BinaryFormat/Dwarf.def"
382 unsigned llvm::dwarf::getCallingConvention(StringRef CCString
) {
383 return StringSwitch
<unsigned>(CCString
)
384 #define HANDLE_DW_CC(ID, NAME) .Case("DW_CC_" #NAME, DW_CC_##NAME)
385 #include "llvm/BinaryFormat/Dwarf.def"
389 StringRef
llvm::dwarf::InlineCodeString(unsigned Code
) {
391 case DW_INL_not_inlined
:
392 return "DW_INL_not_inlined";
394 return "DW_INL_inlined";
395 case DW_INL_declared_not_inlined
:
396 return "DW_INL_declared_not_inlined";
397 case DW_INL_declared_inlined
:
398 return "DW_INL_declared_inlined";
403 StringRef
llvm::dwarf::ArrayOrderString(unsigned Order
) {
405 case DW_ORD_row_major
:
406 return "DW_ORD_row_major";
407 case DW_ORD_col_major
:
408 return "DW_ORD_col_major";
413 StringRef
llvm::dwarf::LNStandardString(unsigned Standard
) {
417 #define HANDLE_DW_LNS(ID, NAME) \
418 case DW_LNS_##NAME: \
419 return "DW_LNS_" #NAME;
420 #include "llvm/BinaryFormat/Dwarf.def"
424 StringRef
llvm::dwarf::LNExtendedString(unsigned Encoding
) {
428 #define HANDLE_DW_LNE(ID, NAME) \
429 case DW_LNE_##NAME: \
430 return "DW_LNE_" #NAME;
431 #include "llvm/BinaryFormat/Dwarf.def"
435 StringRef
llvm::dwarf::MacinfoString(unsigned Encoding
) {
437 // Macinfo Type Encodings
438 case DW_MACINFO_define
:
439 return "DW_MACINFO_define";
440 case DW_MACINFO_undef
:
441 return "DW_MACINFO_undef";
442 case DW_MACINFO_start_file
:
443 return "DW_MACINFO_start_file";
444 case DW_MACINFO_end_file
:
445 return "DW_MACINFO_end_file";
446 case DW_MACINFO_vendor_ext
:
447 return "DW_MACINFO_vendor_ext";
448 case DW_MACINFO_invalid
:
449 return "DW_MACINFO_invalid";
454 unsigned llvm::dwarf::getMacinfo(StringRef MacinfoString
) {
455 return StringSwitch
<unsigned>(MacinfoString
)
456 .Case("DW_MACINFO_define", DW_MACINFO_define
)
457 .Case("DW_MACINFO_undef", DW_MACINFO_undef
)
458 .Case("DW_MACINFO_start_file", DW_MACINFO_start_file
)
459 .Case("DW_MACINFO_end_file", DW_MACINFO_end_file
)
460 .Case("DW_MACINFO_vendor_ext", DW_MACINFO_vendor_ext
)
461 .Default(DW_MACINFO_invalid
);
464 StringRef
llvm::dwarf::RangeListEncodingString(unsigned Encoding
) {
468 #define HANDLE_DW_RLE(ID, NAME) \
469 case DW_RLE_##NAME: \
470 return "DW_RLE_" #NAME;
471 #include "llvm/BinaryFormat/Dwarf.def"
475 StringRef
llvm::dwarf::LocListEncodingString(unsigned Encoding
) {
479 #define HANDLE_DW_LLE(ID, NAME) \
480 case DW_LLE_##NAME: \
481 return "DW_LLE_" #NAME;
482 #include "llvm/BinaryFormat/Dwarf.def"
486 StringRef
llvm::dwarf::CallFrameString(unsigned Encoding
,
487 Triple::ArchType Arch
) {
488 assert(Arch
!= llvm::Triple::ArchType::UnknownArch
);
489 #define SELECT_AARCH64 (Arch == llvm::Triple::aarch64_be || Arch == llvm::Triple::aarch64)
490 #define SELECT_MIPS64 Arch == llvm::Triple::mips64
491 #define SELECT_SPARC (Arch == llvm::Triple::sparc || Arch == llvm::Triple::sparcv9)
492 #define SELECT_X86 (Arch == llvm::Triple::x86 || Arch == llvm::Triple::x86_64)
493 #define HANDLE_DW_CFA(ID, NAME)
494 #define HANDLE_DW_CFA_PRED(ID, NAME, PRED) \
495 if (ID == Encoding && PRED) \
496 return "DW_CFA_" #NAME;
497 #include "llvm/BinaryFormat/Dwarf.def"
502 #define HANDLE_DW_CFA_PRED(ID, NAME, PRED)
503 #define HANDLE_DW_CFA(ID, NAME) \
504 case DW_CFA_##NAME: \
505 return "DW_CFA_" #NAME;
506 #include "llvm/BinaryFormat/Dwarf.def"
511 #undef SELECT_AARCH64
515 StringRef
llvm::dwarf::ApplePropertyString(unsigned Prop
) {
519 #define HANDLE_DW_APPLE_PROPERTY(ID, NAME) \
520 case DW_APPLE_PROPERTY_##NAME: \
521 return "DW_APPLE_PROPERTY_" #NAME;
522 #include "llvm/BinaryFormat/Dwarf.def"
526 StringRef
llvm::dwarf::UnitTypeString(unsigned UT
) {
530 #define HANDLE_DW_UT(ID, NAME) \
532 return "DW_UT_" #NAME;
533 #include "llvm/BinaryFormat/Dwarf.def"
537 StringRef
llvm::dwarf::AtomTypeString(unsigned AT
) {
539 case dwarf::DW_ATOM_null
:
540 return "DW_ATOM_null";
541 case dwarf::DW_ATOM_die_offset
:
542 return "DW_ATOM_die_offset";
543 case DW_ATOM_cu_offset
:
544 return "DW_ATOM_cu_offset";
545 case DW_ATOM_die_tag
:
546 return "DW_ATOM_die_tag";
547 case DW_ATOM_type_flags
:
548 case DW_ATOM_type_type_flags
:
549 return "DW_ATOM_type_flags";
550 case DW_ATOM_qual_name_hash
:
551 return "DW_ATOM_qual_name_hash";
556 StringRef
llvm::dwarf::GDBIndexEntryKindString(GDBIndexEntryKind Kind
) {
575 llvm_unreachable("Unknown GDBIndexEntryKind value");
579 llvm::dwarf::GDBIndexEntryLinkageString(GDBIndexEntryLinkage Linkage
) {
586 llvm_unreachable("Unknown GDBIndexEntryLinkage value");
589 StringRef
llvm::dwarf::AttributeValueString(uint16_t Attr
, unsigned Val
) {
591 case DW_AT_accessibility
:
592 return AccessibilityString(Val
);
593 case DW_AT_virtuality
:
594 return VirtualityString(Val
);
596 return LanguageString(Val
);
598 return AttributeEncodingString(Val
);
599 case DW_AT_decimal_sign
:
600 return DecimalSignString(Val
);
601 case DW_AT_endianity
:
602 return EndianityString(Val
);
603 case DW_AT_visibility
:
604 return VisibilityString(Val
);
605 case DW_AT_identifier_case
:
606 return CaseString(Val
);
607 case DW_AT_calling_convention
:
608 return ConventionString(Val
);
610 return InlineCodeString(Val
);
612 return ArrayOrderString(Val
);
613 case DW_AT_APPLE_runtime_class
:
614 return LanguageString(Val
);
620 StringRef
llvm::dwarf::AtomValueString(uint16_t Atom
, unsigned Val
) {
624 case DW_ATOM_die_tag
:
625 return TagString(Val
);
631 StringRef
llvm::dwarf::IndexString(unsigned Idx
) {
635 #define HANDLE_DW_IDX(ID, NAME) \
636 case DW_IDX_##NAME: \
637 return "DW_IDX_" #NAME;
638 #include "llvm/BinaryFormat/Dwarf.def"
642 Optional
<uint8_t> llvm::dwarf::getFixedFormByteSize(dwarf::Form Form
,
647 return Params
.AddrSize
;
650 case DW_FORM_block
: // ULEB128 length L followed by L bytes.
651 case DW_FORM_block1
: // 1 byte length L followed by L bytes.
652 case DW_FORM_block2
: // 2 byte length L followed by L bytes.
653 case DW_FORM_block4
: // 4 byte length L followed by L bytes.
654 case DW_FORM_string
: // C-string with null terminator.
655 case DW_FORM_sdata
: // SLEB128.
656 case DW_FORM_udata
: // ULEB128.
657 case DW_FORM_ref_udata
: // ULEB128.
658 case DW_FORM_indirect
: // ULEB128.
659 case DW_FORM_exprloc
: // ULEB128 length L followed by L bytes.
660 case DW_FORM_strx
: // ULEB128.
661 case DW_FORM_addrx
: // ULEB128.
662 case DW_FORM_loclistx
: // ULEB128.
663 case DW_FORM_rnglistx
: // ULEB128.
664 case DW_FORM_GNU_addr_index
: // ULEB128.
665 case DW_FORM_GNU_str_index
: // ULEB128.
668 case DW_FORM_ref_addr
:
670 return Params
.getRefAddrByteSize();
691 case DW_FORM_ref_sup4
:
697 case DW_FORM_GNU_ref_alt
:
698 case DW_FORM_GNU_strp_alt
:
699 case DW_FORM_line_strp
:
700 case DW_FORM_sec_offset
:
701 case DW_FORM_strp_sup
:
703 return Params
.getDwarfOffsetByteSize();
708 case DW_FORM_ref_sig8
:
709 case DW_FORM_ref_sup8
:
712 case DW_FORM_flag_present
:
718 case DW_FORM_implicit_const
:
719 // The implicit value is stored in the abbreviation as a SLEB128, and
720 // there no data in debug info.
729 bool llvm::dwarf::isValidFormForVersion(Form F
, unsigned Version
,
731 if (FormVendor(F
) == DWARF_VENDOR_DWARF
) {
732 unsigned FV
= FormVersion(F
);
733 return FV
> 0 && FV
<= Version
;
738 constexpr char llvm::dwarf::EnumTraits
<Attribute
>::Type
[];
739 constexpr char llvm::dwarf::EnumTraits
<Form
>::Type
[];
740 constexpr char llvm::dwarf::EnumTraits
<Index
>::Type
[];
741 constexpr char llvm::dwarf::EnumTraits
<Tag
>::Type
[];