| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 1 | //===--- lib/CodeGen/DIE.cpp - DWARF Info Entries -------------------------===// | 
|  | 2 | // | 
| Chandler Carruth | 2946cd7 | 2019-01-19 08:50:56 +0000 | [diff] [blame] | 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 | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 6 | // | 
|  | 7 | //===----------------------------------------------------------------------===// | 
|  | 8 | // | 
|  | 9 | // Data structures for DWARF info entries. | 
| Eric Christopher | b800ff7 | 2013-01-07 22:40:45 +0000 | [diff] [blame] | 10 | // | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 11 | //===----------------------------------------------------------------------===// | 
|  | 12 |  | 
| Frederic Riss | e541e0b | 2015-01-05 21:29:41 +0000 | [diff] [blame] | 13 | #include "llvm/CodeGen/DIE.h" | 
| David Blaikie | 37c5231 | 2014-10-04 15:49:50 +0000 | [diff] [blame] | 14 | #include "DwarfCompileUnit.h" | 
| Manman Ren | ac8062b | 2013-07-02 23:40:10 +0000 | [diff] [blame] | 15 | #include "DwarfDebug.h" | 
| David Blaikie | 47f615e | 2013-12-17 23:32:35 +0000 | [diff] [blame] | 16 | #include "DwarfUnit.h" | 
| Benjamin Kramer | 4d128a2 | 2010-01-17 07:46:39 +0000 | [diff] [blame] | 17 | #include "llvm/ADT/Twine.h" | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 18 | #include "llvm/CodeGen/AsmPrinter.h" | 
| Nico Weber | 432a388 | 2018-04-30 14:59:11 +0000 | [diff] [blame] | 19 | #include "llvm/Config/llvm-config.h" | 
| Chandler Carruth | 9fb823b | 2013-01-02 11:36:10 +0000 | [diff] [blame] | 20 | #include "llvm/IR/DataLayout.h" | 
| Chris Lattner | 7b26fce | 2009-08-22 20:48:53 +0000 | [diff] [blame] | 21 | #include "llvm/MC/MCAsmInfo.h" | 
| Rafael Espindola | 74dd854 | 2014-10-21 00:25:49 +0000 | [diff] [blame] | 22 | #include "llvm/MC/MCContext.h" | 
| Chris Lattner | 71601e8 | 2010-01-20 07:41:15 +0000 | [diff] [blame] | 23 | #include "llvm/MC/MCStreamer.h" | 
| Chris Lattner | 06d45f6 | 2010-01-16 18:50:28 +0000 | [diff] [blame] | 24 | #include "llvm/MC/MCSymbol.h" | 
| David Greene | 8bc072c | 2009-12-24 00:27:55 +0000 | [diff] [blame] | 25 | #include "llvm/Support/Debug.h" | 
| Torok Edwin | 56d0659 | 2009-07-11 20:10:48 +0000 | [diff] [blame] | 26 | #include "llvm/Support/ErrorHandling.h" | 
| Chris Lattner | 7472571 | 2009-08-23 01:01:17 +0000 | [diff] [blame] | 27 | #include "llvm/Support/Format.h" | 
| Chris Lattner | f5c834f | 2010-01-22 22:09:00 +0000 | [diff] [blame] | 28 | #include "llvm/Support/FormattedStream.h" | 
| Logan Chien | 5b776b7 | 2014-02-22 14:00:39 +0000 | [diff] [blame] | 29 | #include "llvm/Support/LEB128.h" | 
| Eric Christopher | 6764643 | 2013-07-26 17:02:41 +0000 | [diff] [blame] | 30 | #include "llvm/Support/MD5.h" | 
| Benjamin Kramer | 799003b | 2015-03-23 19:32:43 +0000 | [diff] [blame] | 31 | #include "llvm/Support/raw_ostream.h" | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 32 | using namespace llvm; | 
|  | 33 |  | 
| Paul Robinson | 70b3453 | 2017-04-20 19:16:51 +0000 | [diff] [blame] | 34 | #define DEBUG_TYPE "dwarfdebug" | 
|  | 35 |  | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 36 | //===----------------------------------------------------------------------===// | 
|  | 37 | // DIEAbbrevData Implementation | 
|  | 38 | //===----------------------------------------------------------------------===// | 
|  | 39 |  | 
|  | 40 | /// Profile - Used to gather unique data for the abbreviation folding set. | 
|  | 41 | /// | 
|  | 42 | void DIEAbbrevData::Profile(FoldingSetNodeID &ID) const { | 
| Reid Kleckner | ad65f10 | 2013-10-21 19:18:31 +0000 | [diff] [blame] | 43 | // Explicitly cast to an integer type for which FoldingSetNodeID has | 
|  | 44 | // overloads.  Otherwise MSVC 2010 thinks this call is ambiguous. | 
|  | 45 | ID.AddInteger(unsigned(Attribute)); | 
|  | 46 | ID.AddInteger(unsigned(Form)); | 
| Victor Leschuk | d7bfa40 | 2017-03-01 22:13:42 +0000 | [diff] [blame] | 47 | if (Form == dwarf::DW_FORM_implicit_const) | 
|  | 48 | ID.AddInteger(Value); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 49 | } | 
|  | 50 |  | 
|  | 51 | //===----------------------------------------------------------------------===// | 
|  | 52 | // DIEAbbrev Implementation | 
|  | 53 | //===----------------------------------------------------------------------===// | 
|  | 54 |  | 
|  | 55 | /// Profile - Used to gather unique data for the abbreviation folding set. | 
|  | 56 | /// | 
|  | 57 | void DIEAbbrev::Profile(FoldingSetNodeID &ID) const { | 
| Reid Kleckner | ad65f10 | 2013-10-21 19:18:31 +0000 | [diff] [blame] | 58 | ID.AddInteger(unsigned(Tag)); | 
| Eric Christopher | e8f1072 | 2014-03-05 01:44:58 +0000 | [diff] [blame] | 59 | ID.AddInteger(unsigned(Children)); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 60 |  | 
|  | 61 | // For each attribute description. | 
|  | 62 | for (unsigned i = 0, N = Data.size(); i < N; ++i) | 
|  | 63 | Data[i].Profile(ID); | 
|  | 64 | } | 
|  | 65 |  | 
|  | 66 | /// Emit - Print the abbreviation using the specified asm printer. | 
|  | 67 | /// | 
| Frederic Riss | cd04434 | 2015-03-04 02:30:08 +0000 | [diff] [blame] | 68 | void DIEAbbrev::Emit(const AsmPrinter *AP) const { | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 69 | // Emit its Dwarf tag type. | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 70 | AP->emitULEB128(Tag, dwarf::TagString(Tag).data()); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 71 |  | 
|  | 72 | // Emit whether it has children DIEs. | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 73 | AP->emitULEB128((unsigned)Children, dwarf::ChildrenString(Children).data()); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 74 |  | 
|  | 75 | // For each attribute description. | 
|  | 76 | for (unsigned i = 0, N = Data.size(); i < N; ++i) { | 
|  | 77 | const DIEAbbrevData &AttrData = Data[i]; | 
|  | 78 |  | 
|  | 79 | // Emit attribute type. | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 80 | AP->emitULEB128(AttrData.getAttribute(), | 
| Mehdi Amini | 149f6ea | 2016-10-05 05:59:29 +0000 | [diff] [blame] | 81 | dwarf::AttributeString(AttrData.getAttribute()).data()); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 82 |  | 
|  | 83 | // Emit form type. | 
| Paul Robinson | 70b3453 | 2017-04-20 19:16:51 +0000 | [diff] [blame] | 84 | #ifndef NDEBUG | 
|  | 85 | // Could be an assertion, but this way we can see the failing form code | 
|  | 86 | // easily, which helps track down where it came from. | 
|  | 87 | if (!dwarf::isValidFormForVersion(AttrData.getForm(), | 
|  | 88 | AP->getDwarfVersion())) { | 
| Nicola Zaghen | d34e60c | 2018-05-14 12:53:11 +0000 | [diff] [blame] | 89 | LLVM_DEBUG(dbgs() << "Invalid form " << format("0x%x", AttrData.getForm()) | 
|  | 90 | << " for DWARF version " << AP->getDwarfVersion() | 
|  | 91 | << "\n"); | 
| Paul Robinson | 70b3453 | 2017-04-20 19:16:51 +0000 | [diff] [blame] | 92 | llvm_unreachable("Invalid form for specified DWARF version"); | 
|  | 93 | } | 
|  | 94 | #endif | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 95 | AP->emitULEB128(AttrData.getForm(), | 
| Mehdi Amini | 149f6ea | 2016-10-05 05:59:29 +0000 | [diff] [blame] | 96 | dwarf::FormEncodingString(AttrData.getForm()).data()); | 
| Victor Leschuk | cbddae7 | 2017-01-10 21:18:26 +0000 | [diff] [blame] | 97 |  | 
|  | 98 | // Emit value for DW_FORM_implicit_const. | 
| Paul Robinson | 70b3453 | 2017-04-20 19:16:51 +0000 | [diff] [blame] | 99 | if (AttrData.getForm() == dwarf::DW_FORM_implicit_const) | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 100 | AP->emitSLEB128(AttrData.getValue()); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 101 | } | 
|  | 102 |  | 
|  | 103 | // Mark end of abbreviation. | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 104 | AP->emitULEB128(0, "EOM(1)"); | 
|  | 105 | AP->emitULEB128(0, "EOM(2)"); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 106 | } | 
|  | 107 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 108 | LLVM_DUMP_METHOD | 
| Sam Clegg | 705f798 | 2017-06-21 22:19:17 +0000 | [diff] [blame] | 109 | void DIEAbbrev::print(raw_ostream &O) const { | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 110 | O << "Abbreviation @" | 
| Chris Lattner | 7472571 | 2009-08-23 01:01:17 +0000 | [diff] [blame] | 111 | << format("0x%lx", (long)(intptr_t)this) | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 112 | << "  " | 
|  | 113 | << dwarf::TagString(Tag) | 
|  | 114 | << " " | 
| Eric Christopher | e8f1072 | 2014-03-05 01:44:58 +0000 | [diff] [blame] | 115 | << dwarf::ChildrenString(Children) | 
| Chris Lattner | 7472571 | 2009-08-23 01:01:17 +0000 | [diff] [blame] | 116 | << '\n'; | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 117 |  | 
|  | 118 | for (unsigned i = 0, N = Data.size(); i < N; ++i) { | 
|  | 119 | O << "  " | 
|  | 120 | << dwarf::AttributeString(Data[i].getAttribute()) | 
|  | 121 | << "  " | 
| Victor Leschuk | d7bfa40 | 2017-03-01 22:13:42 +0000 | [diff] [blame] | 122 | << dwarf::FormEncodingString(Data[i].getForm()); | 
|  | 123 |  | 
|  | 124 | if (Data[i].getForm() == dwarf::DW_FORM_implicit_const) | 
|  | 125 | O << " " << Data[i].getValue(); | 
|  | 126 |  | 
|  | 127 | O << '\n'; | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 128 | } | 
|  | 129 | } | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 130 |  | 
| Aaron Ballman | 615eb47 | 2017-10-15 14:32:27 +0000 | [diff] [blame] | 131 | #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) | 
| Sam Clegg | 705f798 | 2017-06-21 22:19:17 +0000 | [diff] [blame] | 132 | LLVM_DUMP_METHOD void DIEAbbrev::dump() const { | 
| Matthias Braun | 8c209aa | 2017-01-28 02:02:38 +0000 | [diff] [blame] | 133 | print(dbgs()); | 
|  | 134 | } | 
|  | 135 | #endif | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 136 |  | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 137 | //===----------------------------------------------------------------------===// | 
|  | 138 | // DIEAbbrevSet Implementation | 
|  | 139 | //===----------------------------------------------------------------------===// | 
|  | 140 |  | 
|  | 141 | DIEAbbrevSet::~DIEAbbrevSet() { | 
|  | 142 | for (DIEAbbrev *Abbrev : Abbreviations) | 
|  | 143 | Abbrev->~DIEAbbrev(); | 
|  | 144 | } | 
|  | 145 |  | 
|  | 146 | DIEAbbrev &DIEAbbrevSet::uniqueAbbreviation(DIE &Die) { | 
|  | 147 |  | 
|  | 148 | FoldingSetNodeID ID; | 
|  | 149 | DIEAbbrev Abbrev = Die.generateAbbrev(); | 
|  | 150 | Abbrev.Profile(ID); | 
|  | 151 |  | 
|  | 152 | void *InsertPos; | 
|  | 153 | if (DIEAbbrev *Existing = | 
|  | 154 | AbbreviationsSet.FindNodeOrInsertPos(ID, InsertPos)) { | 
|  | 155 | Die.setAbbrevNumber(Existing->getNumber()); | 
|  | 156 | return *Existing; | 
|  | 157 | } | 
|  | 158 |  | 
|  | 159 | // Move the abbreviation to the heap and assign a number. | 
|  | 160 | DIEAbbrev *New = new (Alloc) DIEAbbrev(std::move(Abbrev)); | 
|  | 161 | Abbreviations.push_back(New); | 
|  | 162 | New->setNumber(Abbreviations.size()); | 
|  | 163 | Die.setAbbrevNumber(Abbreviations.size()); | 
|  | 164 |  | 
|  | 165 | // Store it for lookup. | 
|  | 166 | AbbreviationsSet.InsertNode(New, InsertPos); | 
|  | 167 | return *New; | 
|  | 168 | } | 
|  | 169 |  | 
|  | 170 | void DIEAbbrevSet::Emit(const AsmPrinter *AP, MCSection *Section) const { | 
|  | 171 | if (!Abbreviations.empty()) { | 
|  | 172 | // Start the debug abbrev section. | 
|  | 173 | AP->OutStreamer->SwitchSection(Section); | 
|  | 174 | AP->emitDwarfAbbrevs(Abbreviations); | 
|  | 175 | } | 
|  | 176 | } | 
|  | 177 |  | 
|  | 178 | //===----------------------------------------------------------------------===// | 
|  | 179 | // DIE Implementation | 
|  | 180 | //===----------------------------------------------------------------------===// | 
|  | 181 |  | 
| Greg Clayton | 35630c3 | 2016-12-01 18:56:29 +0000 | [diff] [blame] | 182 | DIE *DIE::getParent() const { | 
|  | 183 | return Owner.dyn_cast<DIE*>(); | 
|  | 184 | } | 
|  | 185 |  | 
| Duncan P. N. Exon Smith | 815a6eb5 | 2015-05-27 22:31:41 +0000 | [diff] [blame] | 186 | DIEAbbrev DIE::generateAbbrev() const { | 
|  | 187 | DIEAbbrev Abbrev(Tag, hasChildren()); | 
| Duncan P. N. Exon Smith | 1ad5ebc | 2015-08-02 20:42:45 +0000 | [diff] [blame] | 188 | for (const DIEValue &V : values()) | 
| Victor Leschuk | cbddae7 | 2017-01-10 21:18:26 +0000 | [diff] [blame] | 189 | if (V.getForm() == dwarf::DW_FORM_implicit_const) | 
|  | 190 | Abbrev.AddImplicitConstAttribute(V.getAttribute(), | 
|  | 191 | V.getDIEInteger().getValue()); | 
|  | 192 | else | 
|  | 193 | Abbrev.AddAttribute(V.getAttribute(), V.getForm()); | 
| Duncan P. N. Exon Smith | 815a6eb5 | 2015-05-27 22:31:41 +0000 | [diff] [blame] | 194 | return Abbrev; | 
|  | 195 | } | 
|  | 196 |  | 
| Igor Kudrin | a845ebd | 2020-09-15 11:32:08 +0700 | [diff] [blame] | 197 | uint64_t DIE::getDebugSectionOffset() const { | 
| Greg Clayton | 35630c3 | 2016-12-01 18:56:29 +0000 | [diff] [blame] | 198 | const DIEUnit *Unit = getUnit(); | 
|  | 199 | assert(Unit && "DIE must be owned by a DIEUnit to get its absolute offset"); | 
| Benjamin Kramer | 6a8704c | 2016-12-01 19:10:10 +0000 | [diff] [blame] | 200 | return Unit->getDebugSectionOffset() + getOffset(); | 
| Manman Ren | 4dbdc90 | 2013-10-31 17:54:35 +0000 | [diff] [blame] | 201 | } | 
|  | 202 |  | 
| Greg Clayton | 35630c3 | 2016-12-01 18:56:29 +0000 | [diff] [blame] | 203 | const DIE *DIE::getUnitDie() const { | 
| Manman Ren | ce20d46 | 2013-10-29 22:57:10 +0000 | [diff] [blame] | 204 | const DIE *p = this; | 
|  | 205 | while (p) { | 
| David Blaikie | 409dd9c | 2013-11-19 23:08:21 +0000 | [diff] [blame] | 206 | if (p->getTag() == dwarf::DW_TAG_compile_unit || | 
|  | 207 | p->getTag() == dwarf::DW_TAG_type_unit) | 
| Manman Ren | ce20d46 | 2013-10-29 22:57:10 +0000 | [diff] [blame] | 208 | return p; | 
|  | 209 | p = p->getParent(); | 
|  | 210 | } | 
| Craig Topper | 353eda4 | 2014-04-24 06:44:33 +0000 | [diff] [blame] | 211 | return nullptr; | 
| Manman Ren | ce20d46 | 2013-10-29 22:57:10 +0000 | [diff] [blame] | 212 | } | 
|  | 213 |  | 
| Eugene Leviant | 7f78d47 | 2019-02-27 14:46:59 +0000 | [diff] [blame] | 214 | DIEUnit *DIE::getUnit() const { | 
| Greg Clayton | 35630c3 | 2016-12-01 18:56:29 +0000 | [diff] [blame] | 215 | const DIE *UnitDie = getUnitDie(); | 
|  | 216 | if (UnitDie) | 
|  | 217 | return UnitDie->Owner.dyn_cast<DIEUnit*>(); | 
|  | 218 | return nullptr; | 
|  | 219 | } | 
|  | 220 |  | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 221 | DIEValue DIE::findAttribute(dwarf::Attribute Attribute) const { | 
| Eric Christopher | 8552e22 | 2013-08-07 01:18:33 +0000 | [diff] [blame] | 222 | // Iterate through all the attributes until we find the one we're | 
|  | 223 | // looking for, if we can't find it return NULL. | 
| Duncan P. N. Exon Smith | 88a8fc5 | 2015-05-27 22:44:06 +0000 | [diff] [blame] | 224 | for (const auto &V : values()) | 
|  | 225 | if (V.getAttribute() == Attribute) | 
|  | 226 | return V; | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 227 | return DIEValue(); | 
| Eric Christopher | 8552e22 | 2013-08-07 01:18:33 +0000 | [diff] [blame] | 228 | } | 
|  | 229 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 230 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | c582114 | 2015-08-02 20:46:49 +0000 | [diff] [blame] | 231 | static void printValues(raw_ostream &O, const DIEValueList &Values, | 
|  | 232 | StringRef Type, unsigned Size, unsigned IndentCount) { | 
|  | 233 | O << Type << ": Size: " << Size << "\n"; | 
|  | 234 |  | 
|  | 235 | unsigned I = 0; | 
|  | 236 | const std::string Indent(IndentCount, ' '); | 
|  | 237 | for (const auto &V : Values.values()) { | 
|  | 238 | O << Indent; | 
|  | 239 | O << "Blk[" << I++ << "]"; | 
|  | 240 | O << "  " << dwarf::FormEncodingString(V.getForm()) << " "; | 
|  | 241 | V.print(O); | 
|  | 242 | O << "\n"; | 
|  | 243 | } | 
|  | 244 | } | 
|  | 245 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 246 | LLVM_DUMP_METHOD | 
| Eric Christopher | 6c6de84 | 2013-05-06 17:50:50 +0000 | [diff] [blame] | 247 | void DIE::print(raw_ostream &O, unsigned IndentCount) const { | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 248 | const std::string Indent(IndentCount, ' '); | 
| Duncan P. N. Exon Smith | c582114 | 2015-08-02 20:46:49 +0000 | [diff] [blame] | 249 | O << Indent << "Die: " << format("0x%lx", (long)(intptr_t) this) | 
|  | 250 | << ", Offset: " << Offset << ", Size: " << Size << "\n"; | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 251 |  | 
| Duncan P. N. Exon Smith | c582114 | 2015-08-02 20:46:49 +0000 | [diff] [blame] | 252 | O << Indent << dwarf::TagString(getTag()) << " " | 
|  | 253 | << dwarf::ChildrenString(hasChildren()) << "\n"; | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 254 |  | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 255 | IndentCount += 2; | 
| Duncan P. N. Exon Smith | 1ad5ebc | 2015-08-02 20:42:45 +0000 | [diff] [blame] | 256 | for (const auto &V : values()) { | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 257 | O << Indent; | 
| Duncan P. N. Exon Smith | c582114 | 2015-08-02 20:46:49 +0000 | [diff] [blame] | 258 | O << dwarf::AttributeString(V.getAttribute()); | 
| Duncan P. N. Exon Smith | 4fb1f9c | 2015-06-25 23:46:41 +0000 | [diff] [blame] | 259 | O << "  " << dwarf::FormEncodingString(V.getForm()) << " "; | 
|  | 260 | V.print(O); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 261 | O << "\n"; | 
|  | 262 | } | 
|  | 263 | IndentCount -= 2; | 
|  | 264 |  | 
| Duncan P. N. Exon Smith | 827200c | 2015-06-25 23:52:10 +0000 | [diff] [blame] | 265 | for (const auto &Child : children()) | 
|  | 266 | Child.print(O, IndentCount + 4); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 267 |  | 
| Duncan P. N. Exon Smith | c582114 | 2015-08-02 20:46:49 +0000 | [diff] [blame] | 268 | O << "\n"; | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 269 | } | 
|  | 270 |  | 
| Aaron Ballman | 615eb47 | 2017-10-15 14:32:27 +0000 | [diff] [blame] | 271 | #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) | 
| Sam Clegg | 705f798 | 2017-06-21 22:19:17 +0000 | [diff] [blame] | 272 | LLVM_DUMP_METHOD void DIE::dump() const { | 
| David Greene | 8bc072c | 2009-12-24 00:27:55 +0000 | [diff] [blame] | 273 | print(dbgs()); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 274 | } | 
| Matthias Braun | 8c209aa | 2017-01-28 02:02:38 +0000 | [diff] [blame] | 275 | #endif | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 276 |  | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 277 | unsigned DIE::computeOffsetsAndAbbrevs(const AsmPrinter *AP, | 
|  | 278 | DIEAbbrevSet &AbbrevSet, | 
|  | 279 | unsigned CUOffset) { | 
|  | 280 | // Unique the abbreviation and fill in the abbreviation number so this DIE | 
|  | 281 | // can be emitted. | 
|  | 282 | const DIEAbbrev &Abbrev = AbbrevSet.uniqueAbbreviation(*this); | 
|  | 283 |  | 
|  | 284 | // Set compile/type unit relative offset of this DIE. | 
|  | 285 | setOffset(CUOffset); | 
|  | 286 |  | 
|  | 287 | // Add the byte size of the abbreviation code. | 
|  | 288 | CUOffset += getULEB128Size(getAbbrevNumber()); | 
|  | 289 |  | 
|  | 290 | // Add the byte size of all the DIE attribute values. | 
|  | 291 | for (const auto &V : values()) | 
|  | 292 | CUOffset += V.SizeOf(AP); | 
|  | 293 |  | 
|  | 294 | // Let the children compute their offsets and abbreviation numbers. | 
|  | 295 | if (hasChildren()) { | 
|  | 296 | (void)Abbrev; | 
|  | 297 | assert(Abbrev.hasChildren() && "Children flag not set"); | 
|  | 298 |  | 
|  | 299 | for (auto &Child : children()) | 
|  | 300 | CUOffset = Child.computeOffsetsAndAbbrevs(AP, AbbrevSet, CUOffset); | 
|  | 301 |  | 
|  | 302 | // Each child chain is terminated with a zero byte, adjust the offset. | 
|  | 303 | CUOffset += sizeof(int8_t); | 
|  | 304 | } | 
|  | 305 |  | 
|  | 306 | // Compute the byte size of this DIE and all of its children correctly. This | 
|  | 307 | // is needed so that top level DIE can help the compile unit set its length | 
|  | 308 | // correctly. | 
|  | 309 | setSize(CUOffset - getOffset()); | 
|  | 310 | return CUOffset; | 
|  | 311 | } | 
|  | 312 |  | 
|  | 313 | //===----------------------------------------------------------------------===// | 
|  | 314 | // DIEUnit Implementation | 
|  | 315 | //===----------------------------------------------------------------------===// | 
| Igor Kudrin | b6b0ff1 | 2020-08-06 17:49:05 +0700 | [diff] [blame] | 316 | DIEUnit::DIEUnit(dwarf::Tag UnitTag) | 
|  | 317 | : Die(UnitTag), Section(nullptr), Offset(0) { | 
| David Blaikie | e40caae | 2016-12-01 21:59:09 +0000 | [diff] [blame] | 318 | Die.Owner = this; | 
| Greg Clayton | 35630c3 | 2016-12-01 18:56:29 +0000 | [diff] [blame] | 319 | assert((UnitTag == dwarf::DW_TAG_compile_unit || | 
| Alexey Lapshin | 789e257 | 2019-11-30 23:48:32 +0300 | [diff] [blame] | 320 | UnitTag == dwarf::DW_TAG_skeleton_unit || | 
| Greg Clayton | 35630c3 | 2016-12-01 18:56:29 +0000 | [diff] [blame] | 321 | UnitTag == dwarf::DW_TAG_type_unit || | 
| Alexey Lapshin | 789e257 | 2019-11-30 23:48:32 +0300 | [diff] [blame] | 322 | UnitTag == dwarf::DW_TAG_partial_unit) && | 
|  | 323 | "expected a unit TAG"); | 
| Greg Clayton | 35630c3 | 2016-12-01 18:56:29 +0000 | [diff] [blame] | 324 | } | 
|  | 325 |  | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 326 | void DIEValue::emitValue(const AsmPrinter *AP) const { | 
| Duncan P. N. Exon Smith | 68b3f30 | 2015-05-23 01:45:07 +0000 | [diff] [blame] | 327 | switch (Ty) { | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 328 | case isNone: | 
|  | 329 | llvm_unreachable("Expected valid DIEValue"); | 
| Duncan P. N. Exon Smith | ff18927 | 2015-05-27 21:15:43 +0000 | [diff] [blame] | 330 | #define HANDLE_DIEVALUE(T)                                                     \ | 
|  | 331 | case is##T:                                                                  \ | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 332 | getDIE##T().emitValue(AP, Form);                                           \ | 
| Duncan P. N. Exon Smith | 68b3f30 | 2015-05-23 01:45:07 +0000 | [diff] [blame] | 333 | break; | 
| Duncan P. N. Exon Smith | ff18927 | 2015-05-27 21:15:43 +0000 | [diff] [blame] | 334 | #include "llvm/CodeGen/DIEValue.def" | 
| Duncan P. N. Exon Smith | 68b3f30 | 2015-05-23 01:45:07 +0000 | [diff] [blame] | 335 | } | 
|  | 336 | } | 
|  | 337 |  | 
| Duncan P. N. Exon Smith | 9dbb501 | 2015-06-24 18:48:11 +0000 | [diff] [blame] | 338 | unsigned DIEValue::SizeOf(const AsmPrinter *AP) const { | 
| Duncan P. N. Exon Smith | 68b3f30 | 2015-05-23 01:45:07 +0000 | [diff] [blame] | 339 | switch (Ty) { | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 340 | case isNone: | 
|  | 341 | llvm_unreachable("Expected valid DIEValue"); | 
| Duncan P. N. Exon Smith | ff18927 | 2015-05-27 21:15:43 +0000 | [diff] [blame] | 342 | #define HANDLE_DIEVALUE(T)                                                     \ | 
|  | 343 | case is##T:                                                                  \ | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 344 | return getDIE##T().SizeOf(AP, Form); | 
| Duncan P. N. Exon Smith | ff18927 | 2015-05-27 21:15:43 +0000 | [diff] [blame] | 345 | #include "llvm/CodeGen/DIEValue.def" | 
| Duncan P. N. Exon Smith | 68b3f30 | 2015-05-23 01:45:07 +0000 | [diff] [blame] | 346 | } | 
| Aaron Ballman | c681c3d | 2015-05-23 14:46:49 +0000 | [diff] [blame] | 347 | llvm_unreachable("Unknown DIE kind"); | 
| Duncan P. N. Exon Smith | 68b3f30 | 2015-05-23 01:45:07 +0000 | [diff] [blame] | 348 | } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 349 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 350 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | 68b3f30 | 2015-05-23 01:45:07 +0000 | [diff] [blame] | 351 | void DIEValue::print(raw_ostream &O) const { | 
|  | 352 | switch (Ty) { | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 353 | case isNone: | 
|  | 354 | llvm_unreachable("Expected valid DIEValue"); | 
| Duncan P. N. Exon Smith | ff18927 | 2015-05-27 21:15:43 +0000 | [diff] [blame] | 355 | #define HANDLE_DIEVALUE(T)                                                     \ | 
|  | 356 | case is##T:                                                                  \ | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 357 | getDIE##T().print(O);                                                      \ | 
| Duncan P. N. Exon Smith | 68b3f30 | 2015-05-23 01:45:07 +0000 | [diff] [blame] | 358 | break; | 
| Duncan P. N. Exon Smith | ff18927 | 2015-05-27 21:15:43 +0000 | [diff] [blame] | 359 | #include "llvm/CodeGen/DIEValue.def" | 
| Duncan P. N. Exon Smith | 68b3f30 | 2015-05-23 01:45:07 +0000 | [diff] [blame] | 360 | } | 
|  | 361 | } | 
|  | 362 |  | 
| Aaron Ballman | 615eb47 | 2017-10-15 14:32:27 +0000 | [diff] [blame] | 363 | #if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP) | 
| Matthias Braun | 8c209aa | 2017-01-28 02:02:38 +0000 | [diff] [blame] | 364 | LLVM_DUMP_METHOD void DIEValue::dump() const { | 
| David Greene | 8bc072c | 2009-12-24 00:27:55 +0000 | [diff] [blame] | 365 | print(dbgs()); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 366 | } | 
| Matthias Braun | 8c209aa | 2017-01-28 02:02:38 +0000 | [diff] [blame] | 367 | #endif | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 368 |  | 
|  | 369 | //===----------------------------------------------------------------------===// | 
|  | 370 | // DIEInteger Implementation | 
|  | 371 | //===----------------------------------------------------------------------===// | 
|  | 372 |  | 
|  | 373 | /// EmitValue - Emit integer of appropriate size. | 
|  | 374 | /// | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 375 | void DIEInteger::emitValue(const AsmPrinter *Asm, dwarf::Form Form) const { | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 376 | switch (Form) { | 
| Victor Leschuk | cbddae7 | 2017-01-10 21:18:26 +0000 | [diff] [blame] | 377 | case dwarf::DW_FORM_implicit_const: | 
| Eric Christopher | bb69a27 | 2012-08-24 01:14:27 +0000 | [diff] [blame] | 378 | case dwarf::DW_FORM_flag_present: | 
|  | 379 | // Emit something to keep the lines and comments in sync. | 
|  | 380 | // FIXME: Is there a better way to do this? | 
| Lang Hames | 9ff69c8 | 2015-04-24 19:11:51 +0000 | [diff] [blame] | 381 | Asm->OutStreamer->AddBlankLine(); | 
| Eric Christopher | bb69a27 | 2012-08-24 01:14:27 +0000 | [diff] [blame] | 382 | return; | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 383 | case dwarf::DW_FORM_flag: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 384 | case dwarf::DW_FORM_ref1: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 385 | case dwarf::DW_FORM_data1: | 
| Paul Robinson | f96e21a | 2017-03-06 22:20:03 +0000 | [diff] [blame] | 386 | case dwarf::DW_FORM_strx1: | 
|  | 387 | case dwarf::DW_FORM_addrx1: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 388 | case dwarf::DW_FORM_ref2: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 389 | case dwarf::DW_FORM_data2: | 
| Paul Robinson | f96e21a | 2017-03-06 22:20:03 +0000 | [diff] [blame] | 390 | case dwarf::DW_FORM_strx2: | 
|  | 391 | case dwarf::DW_FORM_addrx2: | 
| Wolfgang Pieb | 456b555 | 2018-01-26 18:52:58 +0000 | [diff] [blame] | 392 | case dwarf::DW_FORM_strx3: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 393 | case dwarf::DW_FORM_strp: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 394 | case dwarf::DW_FORM_ref4: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 395 | case dwarf::DW_FORM_data4: | 
| Paul Robinson | f96e21a | 2017-03-06 22:20:03 +0000 | [diff] [blame] | 396 | case dwarf::DW_FORM_ref_sup4: | 
|  | 397 | case dwarf::DW_FORM_strx4: | 
|  | 398 | case dwarf::DW_FORM_addrx4: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 399 | case dwarf::DW_FORM_ref8: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 400 | case dwarf::DW_FORM_ref_sig8: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 401 | case dwarf::DW_FORM_data8: | 
| Paul Robinson | f96e21a | 2017-03-06 22:20:03 +0000 | [diff] [blame] | 402 | case dwarf::DW_FORM_ref_sup8: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 403 | case dwarf::DW_FORM_GNU_ref_alt: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 404 | case dwarf::DW_FORM_GNU_strp_alt: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 405 | case dwarf::DW_FORM_line_strp: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 406 | case dwarf::DW_FORM_sec_offset: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 407 | case dwarf::DW_FORM_strp_sup: | 
| Eric Christopher | e8a7b1b | 2012-09-10 23:34:03 +0000 | [diff] [blame] | 408 | case dwarf::DW_FORM_addr: | 
| Frederic Riss | ee17fb9b | 2015-03-04 22:07:36 +0000 | [diff] [blame] | 409 | case dwarf::DW_FORM_ref_addr: | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 410 | Asm->OutStreamer->emitIntValue(Integer, SizeOf(Asm, Form)); | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 411 | return; | 
|  | 412 | case dwarf::DW_FORM_GNU_str_index: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 413 | case dwarf::DW_FORM_GNU_addr_index: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 414 | case dwarf::DW_FORM_ref_udata: | 
| Wolfgang Pieb | 456b555 | 2018-01-26 18:52:58 +0000 | [diff] [blame] | 415 | case dwarf::DW_FORM_strx: | 
| David Blaikie | 161dd3c | 2018-10-20 06:02:15 +0000 | [diff] [blame] | 416 | case dwarf::DW_FORM_addrx: | 
| David Blaikie | c4af8bf | 2018-10-20 07:36:39 +0000 | [diff] [blame] | 417 | case dwarf::DW_FORM_rnglistx: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 418 | case dwarf::DW_FORM_udata: | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 419 | Asm->emitULEB128(Integer); | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 420 | return; | 
|  | 421 | case dwarf::DW_FORM_sdata: | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 422 | Asm->emitSLEB128(Integer); | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 423 | return; | 
| Torok Edwin | fbcc663 | 2009-07-14 16:55:14 +0000 | [diff] [blame] | 424 | default: llvm_unreachable("DIE Value form not supported yet"); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 425 | } | 
|  | 426 | } | 
|  | 427 |  | 
|  | 428 | /// SizeOf - Determine size of integer value in bytes. | 
|  | 429 | /// | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 430 | unsigned DIEInteger::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Igor Kudrin | 027d47d | 2020-09-17 12:47:38 +0700 | [diff] [blame] | 431 | assert(AP && "AsmPrinter is required to set FormParams"); | 
|  | 432 | dwarf::FormParams Params = {AP->getDwarfVersion(), | 
|  | 433 | uint8_t(AP->getPointerSize()), | 
|  | 434 | AP->OutStreamer->getContext().getDwarfFormat()}; | 
| Pavel Labath | 322711f | 2018-03-14 09:39:54 +0000 | [diff] [blame] | 435 |  | 
|  | 436 | if (Optional<uint8_t> FixedSize = dwarf::getFixedFormByteSize(Form, Params)) | 
|  | 437 | return *FixedSize; | 
|  | 438 |  | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 439 | switch (Form) { | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 440 | case dwarf::DW_FORM_GNU_str_index: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 441 | case dwarf::DW_FORM_GNU_addr_index: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 442 | case dwarf::DW_FORM_ref_udata: | 
| Wolfgang Pieb | 456b555 | 2018-01-26 18:52:58 +0000 | [diff] [blame] | 443 | case dwarf::DW_FORM_strx: | 
| David Blaikie | 161dd3c | 2018-10-20 06:02:15 +0000 | [diff] [blame] | 444 | case dwarf::DW_FORM_addrx: | 
| David Blaikie | c4af8bf | 2018-10-20 07:36:39 +0000 | [diff] [blame] | 445 | case dwarf::DW_FORM_rnglistx: | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 446 | case dwarf::DW_FORM_udata: | 
|  | 447 | return getULEB128Size(Integer); | 
|  | 448 | case dwarf::DW_FORM_sdata: | 
|  | 449 | return getSLEB128Size(Integer); | 
| David Blaikie | 46a9f01 | 2012-01-20 21:51:11 +0000 | [diff] [blame] | 450 | default: llvm_unreachable("DIE Value form not supported yet"); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 451 | } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 452 | } | 
|  | 453 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 454 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 455 | void DIEInteger::print(raw_ostream &O) const { | 
| Benjamin Kramer | f3da529 | 2011-11-05 08:57:40 +0000 | [diff] [blame] | 456 | O << "Int: " << (int64_t)Integer << "  0x"; | 
|  | 457 | O.write_hex(Integer); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 458 | } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 459 |  | 
|  | 460 | //===----------------------------------------------------------------------===// | 
| Ulrich Weigand | 396ba8b | 2013-07-02 18:46:26 +0000 | [diff] [blame] | 461 | // DIEExpr Implementation | 
|  | 462 | //===----------------------------------------------------------------------===// | 
|  | 463 |  | 
|  | 464 | /// EmitValue - Emit expression value. | 
|  | 465 | /// | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 466 | void DIEExpr::emitValue(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 467 | AP->emitDebugValue(Expr, SizeOf(AP, Form)); | 
| Ulrich Weigand | 396ba8b | 2013-07-02 18:46:26 +0000 | [diff] [blame] | 468 | } | 
|  | 469 |  | 
|  | 470 | /// SizeOf - Determine size of expression value in bytes. | 
|  | 471 | /// | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 472 | unsigned DIEExpr::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Igor Kudrin | f76a0cd | 2020-07-17 12:46:47 +0700 | [diff] [blame] | 473 | switch (Form) { | 
|  | 474 | case dwarf::DW_FORM_data4: | 
|  | 475 | return 4; | 
|  | 476 | case dwarf::DW_FORM_data8: | 
|  | 477 | return 8; | 
|  | 478 | case dwarf::DW_FORM_sec_offset: | 
| Igor Kudrin | a8058c6 | 2020-09-15 11:30:02 +0700 | [diff] [blame] | 479 | return AP->getDwarfOffsetByteSize(); | 
| Igor Kudrin | f76a0cd | 2020-07-17 12:46:47 +0700 | [diff] [blame] | 480 | default: | 
|  | 481 | llvm_unreachable("DIE Value form not supported yet"); | 
|  | 482 | } | 
| Ulrich Weigand | 396ba8b | 2013-07-02 18:46:26 +0000 | [diff] [blame] | 483 | } | 
|  | 484 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 485 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 486 | void DIEExpr::print(raw_ostream &O) const { O << "Expr: " << *Expr; } | 
| Ulrich Weigand | 396ba8b | 2013-07-02 18:46:26 +0000 | [diff] [blame] | 487 |  | 
|  | 488 | //===----------------------------------------------------------------------===// | 
| Chris Lattner | 8dcf41e | 2010-03-08 22:31:46 +0000 | [diff] [blame] | 489 | // DIELabel Implementation | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 490 | //===----------------------------------------------------------------------===// | 
|  | 491 |  | 
|  | 492 | /// EmitValue - Emit label value. | 
|  | 493 | /// | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 494 | void DIELabel::emitValue(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Igor Kudrin | f98e03a | 2020-08-03 15:04:08 +0700 | [diff] [blame] | 495 | bool IsSectionRelative = Form != dwarf::DW_FORM_addr; | 
|  | 496 | AP->emitLabelReference(Label, SizeOf(AP, Form), IsSectionRelative); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 497 | } | 
|  | 498 |  | 
|  | 499 | /// SizeOf - Determine size of label value in bytes. | 
|  | 500 | /// | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 501 | unsigned DIELabel::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Igor Kudrin | f98e03a | 2020-08-03 15:04:08 +0700 | [diff] [blame] | 502 | switch (Form) { | 
|  | 503 | case dwarf::DW_FORM_data4: | 
|  | 504 | return 4; | 
| Igor Kudrin | 5dd1c59 | 2020-09-15 11:30:30 +0700 | [diff] [blame] | 505 | case dwarf::DW_FORM_data8: | 
|  | 506 | return 8; | 
| Igor Kudrin | f98e03a | 2020-08-03 15:04:08 +0700 | [diff] [blame] | 507 | case dwarf::DW_FORM_sec_offset: | 
|  | 508 | case dwarf::DW_FORM_strp: | 
| Igor Kudrin | a8058c6 | 2020-09-15 11:30:02 +0700 | [diff] [blame] | 509 | return AP->getDwarfOffsetByteSize(); | 
| Igor Kudrin | f98e03a | 2020-08-03 15:04:08 +0700 | [diff] [blame] | 510 | case dwarf::DW_FORM_addr: | 
|  | 511 | return AP->MAI->getCodePointerSize(); | 
|  | 512 | default: | 
|  | 513 | llvm_unreachable("DIE Value form not supported yet"); | 
|  | 514 | } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 515 | } | 
|  | 516 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 517 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 518 | void DIELabel::print(raw_ostream &O) const { O << "Lbl: " << Label->getName(); } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 519 |  | 
|  | 520 | //===----------------------------------------------------------------------===// | 
| Markus Lavin | b86ce21 | 2019-03-19 13:16:28 +0000 | [diff] [blame] | 521 | // DIEBaseTypeRef Implementation | 
|  | 522 | //===----------------------------------------------------------------------===// | 
|  | 523 |  | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 524 | void DIEBaseTypeRef::emitValue(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Markus Lavin | b86ce21 | 2019-03-19 13:16:28 +0000 | [diff] [blame] | 525 | uint64_t Offset = CU->ExprRefedBaseTypes[Index].Die->getOffset(); | 
|  | 526 | assert(Offset < (1ULL << (ULEB128PadSize * 7)) && "Offset wont fit"); | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 527 | AP->emitULEB128(Offset, nullptr, ULEB128PadSize); | 
| Markus Lavin | b86ce21 | 2019-03-19 13:16:28 +0000 | [diff] [blame] | 528 | } | 
|  | 529 |  | 
|  | 530 | unsigned DIEBaseTypeRef::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
|  | 531 | return ULEB128PadSize; | 
|  | 532 | } | 
|  | 533 |  | 
|  | 534 | LLVM_DUMP_METHOD | 
|  | 535 | void DIEBaseTypeRef::print(raw_ostream &O) const { O << "BaseTypeRef: " << Index; } | 
|  | 536 |  | 
|  | 537 | //===----------------------------------------------------------------------===// | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 538 | // DIEDelta Implementation | 
|  | 539 | //===----------------------------------------------------------------------===// | 
|  | 540 |  | 
|  | 541 | /// EmitValue - Emit delta value. | 
|  | 542 | /// | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 543 | void DIEDelta::emitValue(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 544 | AP->emitLabelDifference(LabelHi, LabelLo, SizeOf(AP, Form)); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 545 | } | 
|  | 546 |  | 
|  | 547 | /// SizeOf - Determine size of delta value in bytes. | 
|  | 548 | /// | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 549 | unsigned DIEDelta::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Igor Kudrin | 414b9be | 2020-08-03 15:04:15 +0700 | [diff] [blame] | 550 | switch (Form) { | 
|  | 551 | case dwarf::DW_FORM_data4: | 
|  | 552 | return 4; | 
| Igor Kudrin | cae7c1e | 2020-09-15 11:30:38 +0700 | [diff] [blame] | 553 | case dwarf::DW_FORM_data8: | 
|  | 554 | return 8; | 
| Igor Kudrin | 414b9be | 2020-08-03 15:04:15 +0700 | [diff] [blame] | 555 | case dwarf::DW_FORM_sec_offset: | 
| Igor Kudrin | a8058c6 | 2020-09-15 11:30:02 +0700 | [diff] [blame] | 556 | return AP->getDwarfOffsetByteSize(); | 
| Igor Kudrin | 414b9be | 2020-08-03 15:04:15 +0700 | [diff] [blame] | 557 | default: | 
|  | 558 | llvm_unreachable("DIE Value form not supported yet"); | 
|  | 559 | } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 560 | } | 
|  | 561 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 562 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 563 | void DIEDelta::print(raw_ostream &O) const { | 
| Chris Lattner | bc9210c | 2010-03-08 22:23:36 +0000 | [diff] [blame] | 564 | O << "Del: " << LabelHi->getName() << "-" << LabelLo->getName(); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 565 | } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 566 |  | 
|  | 567 | //===----------------------------------------------------------------------===// | 
| Eric Christopher | 6764643 | 2013-07-26 17:02:41 +0000 | [diff] [blame] | 568 | // DIEString Implementation | 
|  | 569 | //===----------------------------------------------------------------------===// | 
|  | 570 |  | 
|  | 571 | /// EmitValue - Emit string value. | 
|  | 572 | /// | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 573 | void DIEString::emitValue(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Duncan P. N. Exon Smith | f73bcf4 | 2015-05-24 16:40:47 +0000 | [diff] [blame] | 574 | // Index of string in symbol table. | 
| Wolfgang Pieb | 456b555 | 2018-01-26 18:52:58 +0000 | [diff] [blame] | 575 | switch (Form) { | 
|  | 576 | case dwarf::DW_FORM_GNU_str_index: | 
|  | 577 | case dwarf::DW_FORM_strx: | 
|  | 578 | case dwarf::DW_FORM_strx1: | 
|  | 579 | case dwarf::DW_FORM_strx2: | 
|  | 580 | case dwarf::DW_FORM_strx3: | 
|  | 581 | case dwarf::DW_FORM_strx4: | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 582 | DIEInteger(S.getIndex()).emitValue(AP, Form); | 
| Duncan P. N. Exon Smith | f73bcf4 | 2015-05-24 16:40:47 +0000 | [diff] [blame] | 583 | return; | 
| Wolfgang Pieb | 456b555 | 2018-01-26 18:52:58 +0000 | [diff] [blame] | 584 | case dwarf::DW_FORM_strp: | 
|  | 585 | if (AP->MAI->doesDwarfUseRelocationsAcrossSections()) | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 586 | DIELabel(S.getSymbol()).emitValue(AP, Form); | 
| Wolfgang Pieb | 456b555 | 2018-01-26 18:52:58 +0000 | [diff] [blame] | 587 | else | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 588 | DIEInteger(S.getOffset()).emitValue(AP, Form); | 
| Duncan P. N. Exon Smith | f73bcf4 | 2015-05-24 16:40:47 +0000 | [diff] [blame] | 589 | return; | 
| Wolfgang Pieb | 456b555 | 2018-01-26 18:52:58 +0000 | [diff] [blame] | 590 | default: | 
|  | 591 | llvm_unreachable("Expected valid string form"); | 
| Duncan P. N. Exon Smith | f73bcf4 | 2015-05-24 16:40:47 +0000 | [diff] [blame] | 592 | } | 
| Eric Christopher | 6764643 | 2013-07-26 17:02:41 +0000 | [diff] [blame] | 593 | } | 
|  | 594 |  | 
|  | 595 | /// SizeOf - Determine size of delta value in bytes. | 
|  | 596 | /// | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 597 | unsigned DIEString::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Duncan P. N. Exon Smith | f73bcf4 | 2015-05-24 16:40:47 +0000 | [diff] [blame] | 598 | // Index of string in symbol table. | 
| Wolfgang Pieb | 456b555 | 2018-01-26 18:52:58 +0000 | [diff] [blame] | 599 | switch (Form) { | 
|  | 600 | case dwarf::DW_FORM_GNU_str_index: | 
|  | 601 | case dwarf::DW_FORM_strx: | 
|  | 602 | case dwarf::DW_FORM_strx1: | 
|  | 603 | case dwarf::DW_FORM_strx2: | 
|  | 604 | case dwarf::DW_FORM_strx3: | 
|  | 605 | case dwarf::DW_FORM_strx4: | 
| Duncan P. N. Exon Smith | f73bcf4 | 2015-05-24 16:40:47 +0000 | [diff] [blame] | 606 | return DIEInteger(S.getIndex()).SizeOf(AP, Form); | 
| Wolfgang Pieb | 456b555 | 2018-01-26 18:52:58 +0000 | [diff] [blame] | 607 | case dwarf::DW_FORM_strp: | 
|  | 608 | if (AP->MAI->doesDwarfUseRelocationsAcrossSections()) | 
|  | 609 | return DIELabel(S.getSymbol()).SizeOf(AP, Form); | 
|  | 610 | return DIEInteger(S.getOffset()).SizeOf(AP, Form); | 
|  | 611 | default: | 
|  | 612 | llvm_unreachable("Expected valid string form"); | 
|  | 613 | } | 
| Eric Christopher | 6764643 | 2013-07-26 17:02:41 +0000 | [diff] [blame] | 614 | } | 
|  | 615 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 616 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 617 | void DIEString::print(raw_ostream &O) const { | 
| Duncan P. N. Exon Smith | f73bcf4 | 2015-05-24 16:40:47 +0000 | [diff] [blame] | 618 | O << "String: " << S.getString(); | 
| Eric Christopher | 6764643 | 2013-07-26 17:02:41 +0000 | [diff] [blame] | 619 | } | 
| Eric Christopher | 6764643 | 2013-07-26 17:02:41 +0000 | [diff] [blame] | 620 |  | 
|  | 621 | //===----------------------------------------------------------------------===// | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 622 | // DIEInlineString Implementation | 
|  | 623 | //===----------------------------------------------------------------------===// | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 624 | void DIEInlineString::emitValue(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 625 | if (Form == dwarf::DW_FORM_string) { | 
| Fangrui Song | a55daa1 | 2020-02-14 18:16:24 -0800 | [diff] [blame] | 626 | AP->OutStreamer->emitBytes(S); | 
| Rafael Espindola | 4b4d85f | 2018-03-29 23:32:54 +0000 | [diff] [blame] | 627 | AP->emitInt8(0); | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 628 | return; | 
|  | 629 | } | 
|  | 630 | llvm_unreachable("Expected valid string form"); | 
|  | 631 | } | 
|  | 632 |  | 
|  | 633 | unsigned DIEInlineString::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
|  | 634 | // Emit string bytes + NULL byte. | 
|  | 635 | return S.size() + 1; | 
|  | 636 | } | 
|  | 637 |  | 
|  | 638 | LLVM_DUMP_METHOD | 
|  | 639 | void DIEInlineString::print(raw_ostream &O) const { | 
| Benjamin Kramer | eedc405 | 2016-12-09 13:33:41 +0000 | [diff] [blame] | 640 | O << "InlineString: " << S; | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 641 | } | 
|  | 642 |  | 
|  | 643 | //===----------------------------------------------------------------------===// | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 644 | // DIEEntry Implementation | 
|  | 645 | //===----------------------------------------------------------------------===// | 
|  | 646 |  | 
|  | 647 | /// EmitValue - Emit debug information entry offset. | 
|  | 648 | /// | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 649 | void DIEEntry::emitValue(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Eric Christopher | dd50838 | 2014-03-06 00:00:56 +0000 | [diff] [blame] | 650 |  | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 651 | switch (Form) { | 
|  | 652 | case dwarf::DW_FORM_ref1: | 
|  | 653 | case dwarf::DW_FORM_ref2: | 
|  | 654 | case dwarf::DW_FORM_ref4: | 
|  | 655 | case dwarf::DW_FORM_ref8: | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 656 | AP->OutStreamer->emitIntValue(Entry->getOffset(), SizeOf(AP, Form)); | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 657 | return; | 
|  | 658 |  | 
|  | 659 | case dwarf::DW_FORM_ref_udata: | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 660 | AP->emitULEB128(Entry->getOffset()); | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 661 | return; | 
|  | 662 |  | 
|  | 663 | case dwarf::DW_FORM_ref_addr: { | 
| Greg Clayton | 35630c3 | 2016-12-01 18:56:29 +0000 | [diff] [blame] | 664 | // Get the absolute offset for this DIE within the debug info/types section. | 
| Igor Kudrin | a845ebd | 2020-09-15 11:32:08 +0700 | [diff] [blame] | 665 | uint64_t Addr = Entry->getDebugSectionOffset(); | 
| David Blaikie | 85366ac | 2017-04-22 07:53:44 +0000 | [diff] [blame] | 666 | if (const MCSymbol *SectionSym = | 
|  | 667 | Entry->getUnit()->getCrossSectionRelativeBaseAddress()) { | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 668 | AP->emitLabelPlusOffset(SectionSym, Addr, SizeOf(AP, Form), true); | 
| David Blaikie | 85366ac | 2017-04-22 07:53:44 +0000 | [diff] [blame] | 669 | return; | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 670 | } | 
| David Blaikie | 85366ac | 2017-04-22 07:53:44 +0000 | [diff] [blame] | 671 |  | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 672 | AP->OutStreamer->emitIntValue(Addr, SizeOf(AP, Form)); | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 673 | return; | 
|  | 674 | } | 
|  | 675 | default: | 
|  | 676 | llvm_unreachable("Improper form for DIE reference"); | 
|  | 677 | } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 678 | } | 
|  | 679 |  | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 680 | unsigned DIEEntry::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
|  | 681 | switch (Form) { | 
|  | 682 | case dwarf::DW_FORM_ref1: | 
|  | 683 | return 1; | 
|  | 684 | case dwarf::DW_FORM_ref2: | 
|  | 685 | return 2; | 
|  | 686 | case dwarf::DW_FORM_ref4: | 
|  | 687 | return 4; | 
|  | 688 | case dwarf::DW_FORM_ref8: | 
|  | 689 | return 8; | 
|  | 690 | case dwarf::DW_FORM_ref_udata: | 
|  | 691 | return getULEB128Size(Entry->getOffset()); | 
|  | 692 | case dwarf::DW_FORM_ref_addr: | 
|  | 693 | if (AP->getDwarfVersion() == 2) | 
| Konstantin Zhuravlyov | dc77b2e | 2017-04-17 17:41:25 +0000 | [diff] [blame] | 694 | return AP->MAI->getCodePointerSize(); | 
| Greg Clayton | 3462a42 | 2016-12-08 01:03:48 +0000 | [diff] [blame] | 695 | switch (AP->OutStreamer->getContext().getDwarfFormat()) { | 
|  | 696 | case dwarf::DWARF32: | 
|  | 697 | return 4; | 
|  | 698 | case dwarf::DWARF64: | 
|  | 699 | return 8; | 
|  | 700 | } | 
|  | 701 | llvm_unreachable("Invalid DWARF format"); | 
|  | 702 |  | 
|  | 703 | default: | 
|  | 704 | llvm_unreachable("Improper form for DIE reference"); | 
|  | 705 | } | 
| Manman Ren | ac8062b | 2013-07-02 23:40:10 +0000 | [diff] [blame] | 706 | } | 
|  | 707 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 708 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 709 | void DIEEntry::print(raw_ostream &O) const { | 
| David Blaikie | 8dbcc3f | 2014-04-25 19:33:43 +0000 | [diff] [blame] | 710 | O << format("Die: 0x%lx", (long)(intptr_t)&Entry); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 711 | } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 712 |  | 
|  | 713 | //===----------------------------------------------------------------------===// | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 714 | // DIELoc Implementation | 
|  | 715 | //===----------------------------------------------------------------------===// | 
|  | 716 |  | 
|  | 717 | /// ComputeSize - calculate the size of the location expression. | 
|  | 718 | /// | 
| Frederic Riss | cd04434 | 2015-03-04 02:30:08 +0000 | [diff] [blame] | 719 | unsigned DIELoc::ComputeSize(const AsmPrinter *AP) const { | 
| Eric Christopher | 8bdab43 | 2014-02-27 18:36:10 +0000 | [diff] [blame] | 720 | if (!Size) { | 
| Duncan P. N. Exon Smith | 1ad5ebc | 2015-08-02 20:42:45 +0000 | [diff] [blame] | 721 | for (const auto &V : values()) | 
| Duncan P. N. Exon Smith | 9dbb501 | 2015-06-24 18:48:11 +0000 | [diff] [blame] | 722 | Size += V.SizeOf(AP); | 
| Eric Christopher | 8bdab43 | 2014-02-27 18:36:10 +0000 | [diff] [blame] | 723 | } | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 724 |  | 
| Eric Christopher | 8bdab43 | 2014-02-27 18:36:10 +0000 | [diff] [blame] | 725 | return Size; | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 726 | } | 
|  | 727 |  | 
|  | 728 | /// EmitValue - Emit location data. | 
|  | 729 | /// | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 730 | void DIELoc::emitValue(const AsmPrinter *Asm, dwarf::Form Form) const { | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 731 | switch (Form) { | 
|  | 732 | default: llvm_unreachable("Improper form for block"); | 
| Rafael Espindola | 4b4d85f | 2018-03-29 23:32:54 +0000 | [diff] [blame] | 733 | case dwarf::DW_FORM_block1: Asm->emitInt8(Size);    break; | 
|  | 734 | case dwarf::DW_FORM_block2: Asm->emitInt16(Size);   break; | 
|  | 735 | case dwarf::DW_FORM_block4: Asm->emitInt32(Size);   break; | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 736 | case dwarf::DW_FORM_block: | 
|  | 737 | case dwarf::DW_FORM_exprloc: | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 738 | Asm->emitULEB128(Size); | 
|  | 739 | break; | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 740 | } | 
|  | 741 |  | 
| Duncan P. N. Exon Smith | 1ad5ebc | 2015-08-02 20:42:45 +0000 | [diff] [blame] | 742 | for (const auto &V : values()) | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 743 | V.emitValue(Asm); | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 744 | } | 
|  | 745 |  | 
|  | 746 | /// SizeOf - Determine size of location data in bytes. | 
|  | 747 | /// | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 748 | unsigned DIELoc::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 749 | switch (Form) { | 
|  | 750 | case dwarf::DW_FORM_block1: return Size + sizeof(int8_t); | 
|  | 751 | case dwarf::DW_FORM_block2: return Size + sizeof(int16_t); | 
|  | 752 | case dwarf::DW_FORM_block4: return Size + sizeof(int32_t); | 
|  | 753 | case dwarf::DW_FORM_block: | 
|  | 754 | case dwarf::DW_FORM_exprloc: | 
| Logan Chien | 5b776b7 | 2014-02-22 14:00:39 +0000 | [diff] [blame] | 755 | return Size + getULEB128Size(Size); | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 756 | default: llvm_unreachable("Improper form for block"); | 
|  | 757 | } | 
|  | 758 | } | 
|  | 759 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 760 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 761 | void DIELoc::print(raw_ostream &O) const { | 
| Duncan P. N. Exon Smith | c582114 | 2015-08-02 20:46:49 +0000 | [diff] [blame] | 762 | printValues(O, *this, "ExprLoc", Size, 5); | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 763 | } | 
| Eric Christopher | 4a74104 | 2014-02-16 08:46:55 +0000 | [diff] [blame] | 764 |  | 
|  | 765 | //===----------------------------------------------------------------------===// | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 766 | // DIEBlock Implementation | 
|  | 767 | //===----------------------------------------------------------------------===// | 
|  | 768 |  | 
|  | 769 | /// ComputeSize - calculate the size of the block. | 
|  | 770 | /// | 
| Frederic Riss | cd04434 | 2015-03-04 02:30:08 +0000 | [diff] [blame] | 771 | unsigned DIEBlock::ComputeSize(const AsmPrinter *AP) const { | 
| Eric Christopher | 8bdab43 | 2014-02-27 18:36:10 +0000 | [diff] [blame] | 772 | if (!Size) { | 
| Duncan P. N. Exon Smith | 1ad5ebc | 2015-08-02 20:42:45 +0000 | [diff] [blame] | 773 | for (const auto &V : values()) | 
| Duncan P. N. Exon Smith | 9dbb501 | 2015-06-24 18:48:11 +0000 | [diff] [blame] | 774 | Size += V.SizeOf(AP); | 
| Eric Christopher | 8bdab43 | 2014-02-27 18:36:10 +0000 | [diff] [blame] | 775 | } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 776 |  | 
| Eric Christopher | 8bdab43 | 2014-02-27 18:36:10 +0000 | [diff] [blame] | 777 | return Size; | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 778 | } | 
|  | 779 |  | 
|  | 780 | /// EmitValue - Emit block data. | 
|  | 781 | /// | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 782 | void DIEBlock::emitValue(const AsmPrinter *Asm, dwarf::Form Form) const { | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 783 | switch (Form) { | 
| Craig Topper | ee4dab5 | 2012-02-05 08:31:47 +0000 | [diff] [blame] | 784 | default: llvm_unreachable("Improper form for block"); | 
| Rafael Espindola | 4b4d85f | 2018-03-29 23:32:54 +0000 | [diff] [blame] | 785 | case dwarf::DW_FORM_block1: Asm->emitInt8(Size);    break; | 
|  | 786 | case dwarf::DW_FORM_block2: Asm->emitInt16(Size);   break; | 
|  | 787 | case dwarf::DW_FORM_block4: Asm->emitInt32(Size);   break; | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 788 | case dwarf::DW_FORM_block: | 
|  | 789 | Asm->emitULEB128(Size); | 
|  | 790 | break; | 
| Jonas Devlieghere | 9e3e7a9 | 2018-04-02 10:40:43 +0000 | [diff] [blame] | 791 | case dwarf::DW_FORM_string: break; | 
| Paul Robinson | a06f8dc | 2017-12-18 19:08:35 +0000 | [diff] [blame] | 792 | case dwarf::DW_FORM_data16: break; | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 793 | } | 
|  | 794 |  | 
| Duncan P. N. Exon Smith | 1ad5ebc | 2015-08-02 20:42:45 +0000 | [diff] [blame] | 795 | for (const auto &V : values()) | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 796 | V.emitValue(Asm); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 797 | } | 
|  | 798 |  | 
|  | 799 | /// SizeOf - Determine size of block data in bytes. | 
|  | 800 | /// | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 801 | unsigned DIEBlock::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 802 | switch (Form) { | 
|  | 803 | case dwarf::DW_FORM_block1: return Size + sizeof(int8_t); | 
|  | 804 | case dwarf::DW_FORM_block2: return Size + sizeof(int16_t); | 
|  | 805 | case dwarf::DW_FORM_block4: return Size + sizeof(int32_t); | 
| Logan Chien | 5b776b7 | 2014-02-22 14:00:39 +0000 | [diff] [blame] | 806 | case dwarf::DW_FORM_block:  return Size + getULEB128Size(Size); | 
| Paul Robinson | a06f8dc | 2017-12-18 19:08:35 +0000 | [diff] [blame] | 807 | case dwarf::DW_FORM_data16: return 16; | 
| David Blaikie | 46a9f01 | 2012-01-20 21:51:11 +0000 | [diff] [blame] | 808 | default: llvm_unreachable("Improper form for block"); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 809 | } | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 810 | } | 
|  | 811 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 812 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 813 | void DIEBlock::print(raw_ostream &O) const { | 
| Duncan P. N. Exon Smith | c582114 | 2015-08-02 20:46:49 +0000 | [diff] [blame] | 814 | printValues(O, *this, "Blk", Size, 5); | 
| Bill Wendling | 47054f3 | 2009-05-15 00:11:17 +0000 | [diff] [blame] | 815 | } | 
| Eric Christopher | a27220f | 2014-03-05 22:41:20 +0000 | [diff] [blame] | 816 |  | 
|  | 817 | //===----------------------------------------------------------------------===// | 
|  | 818 | // DIELocList Implementation | 
|  | 819 | //===----------------------------------------------------------------------===// | 
|  | 820 |  | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 821 | unsigned DIELocList::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const { | 
| Igor Kudrin | 4e10a18 | 2020-08-03 15:03:37 +0700 | [diff] [blame] | 822 | switch (Form) { | 
|  | 823 | case dwarf::DW_FORM_loclistx: | 
| David Blaikie | 77cfcd7 | 2019-11-12 14:15:37 -0800 | [diff] [blame] | 824 | return getULEB128Size(Index); | 
| Igor Kudrin | 4e10a18 | 2020-08-03 15:03:37 +0700 | [diff] [blame] | 825 | case dwarf::DW_FORM_data4: | 
| Igor Kudrin | a8058c6 | 2020-09-15 11:30:02 +0700 | [diff] [blame] | 826 | assert(!AP->isDwarf64() && | 
|  | 827 | "DW_FORM_data4 is not suitable to emit a pointer to a location list " | 
|  | 828 | "in the 64-bit DWARF format"); | 
| Eric Christopher | a27220f | 2014-03-05 22:41:20 +0000 | [diff] [blame] | 829 | return 4; | 
| Igor Kudrin | a8058c6 | 2020-09-15 11:30:02 +0700 | [diff] [blame] | 830 | case dwarf::DW_FORM_data8: | 
|  | 831 | assert(AP->isDwarf64() && | 
|  | 832 | "DW_FORM_data8 is not suitable to emit a pointer to a location list " | 
|  | 833 | "in the 32-bit DWARF format"); | 
|  | 834 | return 8; | 
| Igor Kudrin | 4e10a18 | 2020-08-03 15:03:37 +0700 | [diff] [blame] | 835 | case dwarf::DW_FORM_sec_offset: | 
| Igor Kudrin | a8058c6 | 2020-09-15 11:30:02 +0700 | [diff] [blame] | 836 | return AP->getDwarfOffsetByteSize(); | 
| Igor Kudrin | 4e10a18 | 2020-08-03 15:03:37 +0700 | [diff] [blame] | 837 | default: | 
|  | 838 | llvm_unreachable("DIE Value form not supported yet"); | 
|  | 839 | } | 
| Eric Christopher | a27220f | 2014-03-05 22:41:20 +0000 | [diff] [blame] | 840 | } | 
|  | 841 |  | 
|  | 842 | /// EmitValue - Emit label value. | 
|  | 843 | /// | 
| Fangrui Song | 7749710 | 2020-02-14 22:40:47 -0800 | [diff] [blame] | 844 | void DIELocList::emitValue(const AsmPrinter *AP, dwarf::Form Form) const { | 
| David Blaikie | 77cfcd7 | 2019-11-12 14:15:37 -0800 | [diff] [blame] | 845 | if (Form == dwarf::DW_FORM_loclistx) { | 
| Fangrui Song | 0bc77a0 | 2020-02-13 13:26:21 -0800 | [diff] [blame] | 846 | AP->emitULEB128(Index); | 
| David Blaikie | 77cfcd7 | 2019-11-12 14:15:37 -0800 | [diff] [blame] | 847 | return; | 
|  | 848 | } | 
| David Blaikie | 9c550ac | 2014-03-25 01:44:02 +0000 | [diff] [blame] | 849 | DwarfDebug *DD = AP->getDwarfDebug(); | 
| Duncan P. N. Exon Smith | 364a300 | 2015-04-17 21:34:47 +0000 | [diff] [blame] | 850 | MCSymbol *Label = DD->getDebugLocs().getList(Index).Label; | 
| Rafael Espindola | 857546e | 2015-06-16 23:22:02 +0000 | [diff] [blame] | 851 | AP->emitDwarfSymbolReference(Label, /*ForceOffset*/ DD->useSplitDwarf()); | 
| Eric Christopher | a27220f | 2014-03-05 22:41:20 +0000 | [diff] [blame] | 852 | } | 
|  | 853 |  | 
| Davide Italiano | c304a0d | 2015-11-24 02:21:43 +0000 | [diff] [blame] | 854 | LLVM_DUMP_METHOD | 
| Duncan P. N. Exon Smith | e7e1d0c | 2015-05-27 22:14:58 +0000 | [diff] [blame] | 855 | void DIELocList::print(raw_ostream &O) const { O << "LocList: " << Index; } |