blob: c927bad4855e1f87595828b275ecaa68aa7e99fa [file] [log] [blame]
Bill Wendling47054f32009-05-15 00:11:17 +00001//===--- lib/CodeGen/DIE.cpp - DWARF Info Entries -------------------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// Data structures for DWARF info entries.
Eric Christopherb800ff72013-01-07 22:40:45 +000011//
Bill Wendling47054f32009-05-15 00:11:17 +000012//===----------------------------------------------------------------------===//
13
Frederic Risse541e0b2015-01-05 21:29:41 +000014#include "llvm/CodeGen/DIE.h"
David Blaikie37c52312014-10-04 15:49:50 +000015#include "DwarfCompileUnit.h"
Manman Renac8062b2013-07-02 23:40:10 +000016#include "DwarfDebug.h"
David Blaikie47f615e2013-12-17 23:32:35 +000017#include "DwarfUnit.h"
Benjamin Kramer4d128a22010-01-17 07:46:39 +000018#include "llvm/ADT/Twine.h"
Bill Wendling47054f32009-05-15 00:11:17 +000019#include "llvm/CodeGen/AsmPrinter.h"
Chandler Carruth9fb823b2013-01-02 11:36:10 +000020#include "llvm/IR/DataLayout.h"
Chris Lattner7b26fce2009-08-22 20:48:53 +000021#include "llvm/MC/MCAsmInfo.h"
Rafael Espindola74dd8542014-10-21 00:25:49 +000022#include "llvm/MC/MCContext.h"
Chris Lattner71601e82010-01-20 07:41:15 +000023#include "llvm/MC/MCStreamer.h"
Chris Lattner06d45f62010-01-16 18:50:28 +000024#include "llvm/MC/MCSymbol.h"
David Greene8bc072c2009-12-24 00:27:55 +000025#include "llvm/Support/Debug.h"
Torok Edwin56d06592009-07-11 20:10:48 +000026#include "llvm/Support/ErrorHandling.h"
Chris Lattner74725712009-08-23 01:01:17 +000027#include "llvm/Support/Format.h"
Chris Lattnerf5c834f2010-01-22 22:09:00 +000028#include "llvm/Support/FormattedStream.h"
Logan Chien5b776b72014-02-22 14:00:39 +000029#include "llvm/Support/LEB128.h"
Eric Christopher67646432013-07-26 17:02:41 +000030#include "llvm/Support/MD5.h"
Benjamin Kramer799003b2015-03-23 19:32:43 +000031#include "llvm/Support/raw_ostream.h"
Bill Wendling47054f32009-05-15 00:11:17 +000032using namespace llvm;
33
34//===----------------------------------------------------------------------===//
35// DIEAbbrevData Implementation
36//===----------------------------------------------------------------------===//
37
38/// Profile - Used to gather unique data for the abbreviation folding set.
39///
40void DIEAbbrevData::Profile(FoldingSetNodeID &ID) const {
Reid Klecknerad65f102013-10-21 19:18:31 +000041 // Explicitly cast to an integer type for which FoldingSetNodeID has
42 // overloads. Otherwise MSVC 2010 thinks this call is ambiguous.
43 ID.AddInteger(unsigned(Attribute));
44 ID.AddInteger(unsigned(Form));
Bill Wendling47054f32009-05-15 00:11:17 +000045}
46
47//===----------------------------------------------------------------------===//
48// DIEAbbrev Implementation
49//===----------------------------------------------------------------------===//
50
51/// Profile - Used to gather unique data for the abbreviation folding set.
52///
53void DIEAbbrev::Profile(FoldingSetNodeID &ID) const {
Reid Klecknerad65f102013-10-21 19:18:31 +000054 ID.AddInteger(unsigned(Tag));
Eric Christophere8f10722014-03-05 01:44:58 +000055 ID.AddInteger(unsigned(Children));
Bill Wendling47054f32009-05-15 00:11:17 +000056
57 // For each attribute description.
58 for (unsigned i = 0, N = Data.size(); i < N; ++i)
59 Data[i].Profile(ID);
60}
61
62/// Emit - Print the abbreviation using the specified asm printer.
63///
Frederic Risscd044342015-03-04 02:30:08 +000064void DIEAbbrev::Emit(const AsmPrinter *AP) const {
Bill Wendling47054f32009-05-15 00:11:17 +000065 // Emit its Dwarf tag type.
Chris Lattner3a383cb2010-04-05 00:13:49 +000066 AP->EmitULEB128(Tag, dwarf::TagString(Tag));
Bill Wendling47054f32009-05-15 00:11:17 +000067
68 // Emit whether it has children DIEs.
Eric Christophere8f10722014-03-05 01:44:58 +000069 AP->EmitULEB128((unsigned)Children, dwarf::ChildrenString(Children));
Bill Wendling47054f32009-05-15 00:11:17 +000070
71 // For each attribute description.
72 for (unsigned i = 0, N = Data.size(); i < N; ++i) {
73 const DIEAbbrevData &AttrData = Data[i];
74
75 // Emit attribute type.
Chris Lattner3a383cb2010-04-05 00:13:49 +000076 AP->EmitULEB128(AttrData.getAttribute(),
Nick Lewycky019d2552011-07-29 03:49:23 +000077 dwarf::AttributeString(AttrData.getAttribute()));
Bill Wendling47054f32009-05-15 00:11:17 +000078
79 // Emit form type.
Chris Lattner3a383cb2010-04-05 00:13:49 +000080 AP->EmitULEB128(AttrData.getForm(),
81 dwarf::FormEncodingString(AttrData.getForm()));
Bill Wendling47054f32009-05-15 00:11:17 +000082 }
83
84 // Mark end of abbreviation.
Chris Lattner3a383cb2010-04-05 00:13:49 +000085 AP->EmitULEB128(0, "EOM(1)");
86 AP->EmitULEB128(0, "EOM(2)");
Bill Wendling47054f32009-05-15 00:11:17 +000087}
88
89#ifndef NDEBUG
Chris Lattner74725712009-08-23 01:01:17 +000090void DIEAbbrev::print(raw_ostream &O) {
Bill Wendling47054f32009-05-15 00:11:17 +000091 O << "Abbreviation @"
Chris Lattner74725712009-08-23 01:01:17 +000092 << format("0x%lx", (long)(intptr_t)this)
Bill Wendling47054f32009-05-15 00:11:17 +000093 << " "
94 << dwarf::TagString(Tag)
95 << " "
Eric Christophere8f10722014-03-05 01:44:58 +000096 << dwarf::ChildrenString(Children)
Chris Lattner74725712009-08-23 01:01:17 +000097 << '\n';
Bill Wendling47054f32009-05-15 00:11:17 +000098
99 for (unsigned i = 0, N = Data.size(); i < N; ++i) {
100 O << " "
101 << dwarf::AttributeString(Data[i].getAttribute())
102 << " "
103 << dwarf::FormEncodingString(Data[i].getForm())
Chris Lattner74725712009-08-23 01:01:17 +0000104 << '\n';
Bill Wendling47054f32009-05-15 00:11:17 +0000105 }
106}
David Greene8bc072c2009-12-24 00:27:55 +0000107void DIEAbbrev::dump() { print(dbgs()); }
Bill Wendling47054f32009-05-15 00:11:17 +0000108#endif
109
Eric Christopherd89221e2013-11-21 01:01:30 +0000110/// Climb up the parent chain to get the unit DIE to which this DIE
Manman Rence20d462013-10-29 22:57:10 +0000111/// belongs.
David Blaikie409dd9c2013-11-19 23:08:21 +0000112const DIE *DIE::getUnit() const {
113 const DIE *Cu = getUnitOrNull();
Manman Ren4dbdc902013-10-31 17:54:35 +0000114 assert(Cu && "We should not have orphaned DIEs.");
115 return Cu;
116}
117
Eric Christopherd89221e2013-11-21 01:01:30 +0000118/// Climb up the parent chain to get the unit DIE this DIE belongs
Manman Ren4dbdc902013-10-31 17:54:35 +0000119/// to. Return NULL if DIE is not added to an owner yet.
David Blaikie409dd9c2013-11-19 23:08:21 +0000120const DIE *DIE::getUnitOrNull() const {
Manman Rence20d462013-10-29 22:57:10 +0000121 const DIE *p = this;
122 while (p) {
David Blaikie409dd9c2013-11-19 23:08:21 +0000123 if (p->getTag() == dwarf::DW_TAG_compile_unit ||
124 p->getTag() == dwarf::DW_TAG_type_unit)
Manman Rence20d462013-10-29 22:57:10 +0000125 return p;
126 p = p->getParent();
127 }
Craig Topper353eda42014-04-24 06:44:33 +0000128 return nullptr;
Manman Rence20d462013-10-29 22:57:10 +0000129}
130
Eric Christopher0af53e22014-03-05 01:10:59 +0000131DIEValue *DIE::findAttribute(dwarf::Attribute Attribute) const {
Eric Christopher8552e222013-08-07 01:18:33 +0000132 const SmallVectorImpl<DIEValue *> &Values = getValues();
133 const DIEAbbrev &Abbrevs = getAbbrev();
134
135 // Iterate through all the attributes until we find the one we're
136 // looking for, if we can't find it return NULL.
137 for (size_t i = 0; i < Values.size(); ++i)
138 if (Abbrevs.getData()[i].getAttribute() == Attribute)
139 return Values[i];
Craig Topper353eda42014-04-24 06:44:33 +0000140 return nullptr;
Eric Christopher8552e222013-08-07 01:18:33 +0000141}
142
Bill Wendling47054f32009-05-15 00:11:17 +0000143#ifndef NDEBUG
Eric Christopher6c6de842013-05-06 17:50:50 +0000144void DIE::print(raw_ostream &O, unsigned IndentCount) const {
Bill Wendling47054f32009-05-15 00:11:17 +0000145 const std::string Indent(IndentCount, ' ');
146 bool isBlock = Abbrev.getTag() == 0;
147
148 if (!isBlock) {
149 O << Indent
150 << "Die: "
Chris Lattner74725712009-08-23 01:01:17 +0000151 << format("0x%lx", (long)(intptr_t)this)
Bill Wendling47054f32009-05-15 00:11:17 +0000152 << ", Offset: " << Offset
Chris Lattner3d72a672010-03-09 23:38:23 +0000153 << ", Size: " << Size << "\n";
Bill Wendling47054f32009-05-15 00:11:17 +0000154
155 O << Indent
156 << dwarf::TagString(Abbrev.getTag())
157 << " "
Eric Christophere8f10722014-03-05 01:44:58 +0000158 << dwarf::ChildrenString(Abbrev.hasChildren()) << "\n";
Bill Wendling47054f32009-05-15 00:11:17 +0000159 } else {
Chris Lattner3d72a672010-03-09 23:38:23 +0000160 O << "Size: " << Size << "\n";
Bill Wendling47054f32009-05-15 00:11:17 +0000161 }
Bill Wendling47054f32009-05-15 00:11:17 +0000162
Eric Christopher4887c8f2013-03-29 23:34:06 +0000163 const SmallVectorImpl<DIEAbbrevData> &Data = Abbrev.getData();
Bill Wendling47054f32009-05-15 00:11:17 +0000164
165 IndentCount += 2;
166 for (unsigned i = 0, N = Data.size(); i < N; ++i) {
167 O << Indent;
168
169 if (!isBlock)
170 O << dwarf::AttributeString(Data[i].getAttribute());
171 else
172 O << "Blk[" << i << "]";
173
174 O << " "
175 << dwarf::FormEncodingString(Data[i].getForm())
176 << " ";
177 Values[i]->print(O);
178 O << "\n";
179 }
180 IndentCount -= 2;
181
182 for (unsigned j = 0, M = Children.size(); j < M; ++j) {
Eric Christopher6c6de842013-05-06 17:50:50 +0000183 Children[j]->print(O, IndentCount+4);
Bill Wendling47054f32009-05-15 00:11:17 +0000184 }
185
186 if (!isBlock) O << "\n";
Bill Wendling47054f32009-05-15 00:11:17 +0000187}
188
189void DIE::dump() {
David Greene8bc072c2009-12-24 00:27:55 +0000190 print(dbgs());
Bill Wendling47054f32009-05-15 00:11:17 +0000191}
192#endif
193
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000194void DIEValue::EmitValue(const AsmPrinter *AP, dwarf::Form Form) const {
195 switch (Ty) {
196#define EMIT_VALUE_IMPL(Kind) \
197 case is##Kind: \
198 cast<DIE##Kind>(this)->EmitValueImpl(AP, Form); \
199 break;
200 EMIT_VALUE_IMPL(Integer)
201 EMIT_VALUE_IMPL(String)
202 EMIT_VALUE_IMPL(Expr)
203 EMIT_VALUE_IMPL(Label)
204 EMIT_VALUE_IMPL(Delta)
205 EMIT_VALUE_IMPL(Entry)
206 EMIT_VALUE_IMPL(TypeSignature)
207 EMIT_VALUE_IMPL(Block)
208 EMIT_VALUE_IMPL(Loc)
209 EMIT_VALUE_IMPL(LocList)
210#undef EMIT_VALUE_IMPL
211 }
212}
213
214unsigned DIEValue::SizeOf(const AsmPrinter *AP, dwarf::Form Form) const {
215 switch (Ty) {
216#define SIZE_OF_IMPL(Kind) \
217 case is##Kind: \
218 return cast<DIE##Kind>(this)->SizeOfImpl(AP, Form);
219 SIZE_OF_IMPL(Integer)
220 SIZE_OF_IMPL(String)
221 SIZE_OF_IMPL(Expr)
222 SIZE_OF_IMPL(Label)
223 SIZE_OF_IMPL(Delta)
224 SIZE_OF_IMPL(Entry)
225 SIZE_OF_IMPL(TypeSignature)
226 SIZE_OF_IMPL(Block)
227 SIZE_OF_IMPL(Loc)
228 SIZE_OF_IMPL(LocList)
229#undef SIZE_OF_IMPL
230 }
Aaron Ballmanc681c3d2015-05-23 14:46:49 +0000231 llvm_unreachable("Unknown DIE kind");
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000232}
Bill Wendling47054f32009-05-15 00:11:17 +0000233
234#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000235void DIEValue::print(raw_ostream &O) const {
236 switch (Ty) {
237#define PRINT_IMPL(Kind) \
238 case is##Kind: \
239 cast<DIE##Kind>(this)->printImpl(O); \
240 break;
241 PRINT_IMPL(Integer)
242 PRINT_IMPL(String)
243 PRINT_IMPL(Expr)
244 PRINT_IMPL(Label)
245 PRINT_IMPL(Delta)
246 PRINT_IMPL(Entry)
247 PRINT_IMPL(TypeSignature)
248 PRINT_IMPL(Block)
249 PRINT_IMPL(Loc)
250 PRINT_IMPL(LocList)
251#undef PRINT_IMPL
252 }
253}
254
Eric Christopher65ac02a2013-05-31 22:50:40 +0000255void DIEValue::dump() const {
David Greene8bc072c2009-12-24 00:27:55 +0000256 print(dbgs());
Bill Wendling47054f32009-05-15 00:11:17 +0000257}
258#endif
259
260//===----------------------------------------------------------------------===//
261// DIEInteger Implementation
262//===----------------------------------------------------------------------===//
263
264/// EmitValue - Emit integer of appropriate size.
265///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000266void DIEInteger::EmitValueImpl(const AsmPrinter *Asm, dwarf::Form Form) const {
Chris Lattner71601e82010-01-20 07:41:15 +0000267 unsigned Size = ~0U;
Bill Wendling47054f32009-05-15 00:11:17 +0000268 switch (Form) {
Eric Christopherbb69a272012-08-24 01:14:27 +0000269 case dwarf::DW_FORM_flag_present:
270 // Emit something to keep the lines and comments in sync.
271 // FIXME: Is there a better way to do this?
Lang Hames9ff69c82015-04-24 19:11:51 +0000272 Asm->OutStreamer->AddBlankLine();
Eric Christopherbb69a272012-08-24 01:14:27 +0000273 return;
Bill Wendling47054f32009-05-15 00:11:17 +0000274 case dwarf::DW_FORM_flag: // Fall thru
275 case dwarf::DW_FORM_ref1: // Fall thru
Chris Lattner71601e82010-01-20 07:41:15 +0000276 case dwarf::DW_FORM_data1: Size = 1; break;
Bill Wendling47054f32009-05-15 00:11:17 +0000277 case dwarf::DW_FORM_ref2: // Fall thru
Chris Lattner71601e82010-01-20 07:41:15 +0000278 case dwarf::DW_FORM_data2: Size = 2; break;
Eric Christopher18266172013-01-17 02:59:59 +0000279 case dwarf::DW_FORM_sec_offset: // Fall thru
Frederic Rissee17fb9b2015-03-04 22:07:36 +0000280 case dwarf::DW_FORM_strp: // Fall thru
Bill Wendling47054f32009-05-15 00:11:17 +0000281 case dwarf::DW_FORM_ref4: // Fall thru
Chris Lattner71601e82010-01-20 07:41:15 +0000282 case dwarf::DW_FORM_data4: Size = 4; break;
Bill Wendling47054f32009-05-15 00:11:17 +0000283 case dwarf::DW_FORM_ref8: // Fall thru
David Blaikie409dd9c2013-11-19 23:08:21 +0000284 case dwarf::DW_FORM_ref_sig8: // Fall thru
Chris Lattner71601e82010-01-20 07:41:15 +0000285 case dwarf::DW_FORM_data8: Size = 8; break;
Eric Christopher2cbd5762013-01-07 19:32:41 +0000286 case dwarf::DW_FORM_GNU_str_index: Asm->EmitULEB128(Integer); return;
Eric Christopher962c9082013-01-15 23:56:56 +0000287 case dwarf::DW_FORM_GNU_addr_index: Asm->EmitULEB128(Integer); return;
Chris Lattner9efd1182010-04-04 19:09:29 +0000288 case dwarf::DW_FORM_udata: Asm->EmitULEB128(Integer); return;
289 case dwarf::DW_FORM_sdata: Asm->EmitSLEB128(Integer); return;
Eric Christophere8a7b1b2012-09-10 23:34:03 +0000290 case dwarf::DW_FORM_addr:
Chandler Carruth5da3f052012-11-01 09:14:31 +0000291 Size = Asm->getDataLayout().getPointerSize(); break;
Frederic Rissee17fb9b2015-03-04 22:07:36 +0000292 case dwarf::DW_FORM_ref_addr:
293 Size = SizeOf(Asm, dwarf::DW_FORM_ref_addr);
294 break;
Torok Edwinfbcc6632009-07-14 16:55:14 +0000295 default: llvm_unreachable("DIE Value form not supported yet");
Bill Wendling47054f32009-05-15 00:11:17 +0000296 }
Lang Hames9ff69c82015-04-24 19:11:51 +0000297 Asm->OutStreamer->EmitIntValue(Integer, Size);
Bill Wendling47054f32009-05-15 00:11:17 +0000298}
299
300/// SizeOf - Determine size of integer value in bytes.
301///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000302unsigned DIEInteger::SizeOfImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Bill Wendling47054f32009-05-15 00:11:17 +0000303 switch (Form) {
Eric Christopher2a4e6162012-08-29 17:59:32 +0000304 case dwarf::DW_FORM_flag_present: return 0;
Bill Wendling47054f32009-05-15 00:11:17 +0000305 case dwarf::DW_FORM_flag: // Fall thru
306 case dwarf::DW_FORM_ref1: // Fall thru
307 case dwarf::DW_FORM_data1: return sizeof(int8_t);
308 case dwarf::DW_FORM_ref2: // Fall thru
309 case dwarf::DW_FORM_data2: return sizeof(int16_t);
Eric Christopher18266172013-01-17 02:59:59 +0000310 case dwarf::DW_FORM_sec_offset: // Fall thru
Frederic Rissee17fb9b2015-03-04 22:07:36 +0000311 case dwarf::DW_FORM_strp: // Fall thru
Bill Wendling47054f32009-05-15 00:11:17 +0000312 case dwarf::DW_FORM_ref4: // Fall thru
313 case dwarf::DW_FORM_data4: return sizeof(int32_t);
314 case dwarf::DW_FORM_ref8: // Fall thru
David Blaikie409dd9c2013-11-19 23:08:21 +0000315 case dwarf::DW_FORM_ref_sig8: // Fall thru
Bill Wendling47054f32009-05-15 00:11:17 +0000316 case dwarf::DW_FORM_data8: return sizeof(int64_t);
Logan Chien5b776b72014-02-22 14:00:39 +0000317 case dwarf::DW_FORM_GNU_str_index: return getULEB128Size(Integer);
318 case dwarf::DW_FORM_GNU_addr_index: return getULEB128Size(Integer);
319 case dwarf::DW_FORM_udata: return getULEB128Size(Integer);
320 case dwarf::DW_FORM_sdata: return getSLEB128Size(Integer);
Chandler Carruth5da3f052012-11-01 09:14:31 +0000321 case dwarf::DW_FORM_addr: return AP->getDataLayout().getPointerSize();
Frederic Rissee17fb9b2015-03-04 22:07:36 +0000322 case dwarf::DW_FORM_ref_addr:
Lang Hames9ff69c82015-04-24 19:11:51 +0000323 if (AP->OutStreamer->getContext().getDwarfVersion() == 2)
Frederic Rissee17fb9b2015-03-04 22:07:36 +0000324 return AP->getDataLayout().getPointerSize();
325 return sizeof(int32_t);
David Blaikie46a9f012012-01-20 21:51:11 +0000326 default: llvm_unreachable("DIE Value form not supported yet");
Bill Wendling47054f32009-05-15 00:11:17 +0000327 }
Bill Wendling47054f32009-05-15 00:11:17 +0000328}
329
Bill Wendling47054f32009-05-15 00:11:17 +0000330#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000331void DIEInteger::printImpl(raw_ostream &O) const {
Benjamin Kramerf3da5292011-11-05 08:57:40 +0000332 O << "Int: " << (int64_t)Integer << " 0x";
333 O.write_hex(Integer);
Bill Wendling47054f32009-05-15 00:11:17 +0000334}
335#endif
336
337//===----------------------------------------------------------------------===//
Ulrich Weigand396ba8b2013-07-02 18:46:26 +0000338// DIEExpr Implementation
339//===----------------------------------------------------------------------===//
340
341/// EmitValue - Emit expression value.
342///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000343void DIEExpr::EmitValueImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Lang Hames9ff69c82015-04-24 19:11:51 +0000344 AP->OutStreamer->EmitValue(Expr, SizeOf(AP, Form));
Ulrich Weigand396ba8b2013-07-02 18:46:26 +0000345}
346
347/// SizeOf - Determine size of expression value in bytes.
348///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000349unsigned DIEExpr::SizeOfImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Ulrich Weigand396ba8b2013-07-02 18:46:26 +0000350 if (Form == dwarf::DW_FORM_data4) return 4;
351 if (Form == dwarf::DW_FORM_sec_offset) return 4;
352 if (Form == dwarf::DW_FORM_strp) return 4;
353 return AP->getDataLayout().getPointerSize();
354}
355
356#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000357void DIEExpr::printImpl(raw_ostream &O) const {
Ulrich Weigand396ba8b2013-07-02 18:46:26 +0000358 O << "Expr: ";
359 Expr->print(O);
360}
361#endif
362
363//===----------------------------------------------------------------------===//
Chris Lattner8dcf41e2010-03-08 22:31:46 +0000364// DIELabel Implementation
Bill Wendling47054f32009-05-15 00:11:17 +0000365//===----------------------------------------------------------------------===//
366
367/// EmitValue - Emit label value.
368///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000369void DIELabel::EmitValueImpl(const AsmPrinter *AP, dwarf::Form Form) const {
David Blaikief2443192013-10-21 17:28:37 +0000370 AP->EmitLabelReference(Label, SizeOf(AP, Form),
371 Form == dwarf::DW_FORM_strp ||
372 Form == dwarf::DW_FORM_sec_offset ||
373 Form == dwarf::DW_FORM_ref_addr);
Bill Wendling47054f32009-05-15 00:11:17 +0000374}
375
376/// SizeOf - Determine size of label value in bytes.
377///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000378unsigned DIELabel::SizeOfImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Bill Wendling47054f32009-05-15 00:11:17 +0000379 if (Form == dwarf::DW_FORM_data4) return 4;
Eric Christopher4c7765f2013-01-17 03:00:04 +0000380 if (Form == dwarf::DW_FORM_sec_offset) return 4;
Nick Lewyckyd59c0ca2011-10-27 06:44:11 +0000381 if (Form == dwarf::DW_FORM_strp) return 4;
Chandler Carruth5da3f052012-11-01 09:14:31 +0000382 return AP->getDataLayout().getPointerSize();
Bill Wendling47054f32009-05-15 00:11:17 +0000383}
384
Bill Wendling47054f32009-05-15 00:11:17 +0000385#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000386void DIELabel::printImpl(raw_ostream &O) const {
Ulrich Weigand396ba8b2013-07-02 18:46:26 +0000387 O << "Lbl: " << Label->getName();
Bill Wendling47054f32009-05-15 00:11:17 +0000388}
389#endif
390
391//===----------------------------------------------------------------------===//
Bill Wendling47054f32009-05-15 00:11:17 +0000392// DIEDelta Implementation
393//===----------------------------------------------------------------------===//
394
395/// EmitValue - Emit delta value.
396///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000397void DIEDelta::EmitValueImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Chris Lattner5a00dea2010-04-05 00:18:22 +0000398 AP->EmitLabelDifference(LabelHi, LabelLo, SizeOf(AP, Form));
Bill Wendling47054f32009-05-15 00:11:17 +0000399}
400
401/// SizeOf - Determine size of delta value in bytes.
402///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000403unsigned DIEDelta::SizeOfImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Bill Wendling47054f32009-05-15 00:11:17 +0000404 if (Form == dwarf::DW_FORM_data4) return 4;
Eric Christopher33ff6972013-11-21 23:46:41 +0000405 if (Form == dwarf::DW_FORM_sec_offset) return 4;
Nick Lewyckyd59c0ca2011-10-27 06:44:11 +0000406 if (Form == dwarf::DW_FORM_strp) return 4;
Chandler Carruth5da3f052012-11-01 09:14:31 +0000407 return AP->getDataLayout().getPointerSize();
Bill Wendling47054f32009-05-15 00:11:17 +0000408}
409
Bill Wendling47054f32009-05-15 00:11:17 +0000410#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000411void DIEDelta::printImpl(raw_ostream &O) const {
Chris Lattnerbc9210c2010-03-08 22:23:36 +0000412 O << "Del: " << LabelHi->getName() << "-" << LabelLo->getName();
Bill Wendling47054f32009-05-15 00:11:17 +0000413}
414#endif
415
416//===----------------------------------------------------------------------===//
Eric Christopher67646432013-07-26 17:02:41 +0000417// DIEString Implementation
418//===----------------------------------------------------------------------===//
419
420/// EmitValue - Emit string value.
421///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000422void DIEString::EmitValueImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Eric Christopher67646432013-07-26 17:02:41 +0000423 Access->EmitValue(AP, Form);
424}
425
426/// SizeOf - Determine size of delta value in bytes.
427///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000428unsigned DIEString::SizeOfImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Eric Christopher67646432013-07-26 17:02:41 +0000429 return Access->SizeOf(AP, Form);
430}
431
432#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000433void DIEString::printImpl(raw_ostream &O) const {
Eric Christopher67646432013-07-26 17:02:41 +0000434 O << "String: " << Str << "\tSymbol: ";
435 Access->print(O);
436}
437#endif
438
439//===----------------------------------------------------------------------===//
Bill Wendling47054f32009-05-15 00:11:17 +0000440// DIEEntry Implementation
441//===----------------------------------------------------------------------===//
442
443/// EmitValue - Emit debug information entry offset.
444///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000445void DIEEntry::EmitValueImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Eric Christopherdd508382014-03-06 00:00:56 +0000446
447 if (Form == dwarf::DW_FORM_ref_addr) {
448 const DwarfDebug *DD = AP->getDwarfDebug();
David Blaikie8dbcc3f2014-04-25 19:33:43 +0000449 unsigned Addr = Entry.getOffset();
Eric Christopherdd508382014-03-06 00:00:56 +0000450 assert(!DD->useSplitDwarf() && "TODO: dwo files can't have relocations.");
451 // For DW_FORM_ref_addr, output the offset from beginning of debug info
452 // section. Entry->getOffset() returns the offset from start of the
453 // compile unit.
David Blaikie8dbcc3f2014-04-25 19:33:43 +0000454 DwarfCompileUnit *CU = DD->lookupUnit(Entry.getUnit());
Eric Christopherdd508382014-03-06 00:00:56 +0000455 assert(CU && "CUDie should belong to a CU.");
456 Addr += CU->getDebugInfoOffset();
457 if (AP->MAI->doesDwarfUseRelocationsAcrossSections())
458 AP->EmitLabelPlusOffset(CU->getSectionSym(), Addr,
459 DIEEntry::getRefAddrSize(AP));
460 else
Lang Hames9ff69c82015-04-24 19:11:51 +0000461 AP->OutStreamer->EmitIntValue(Addr, DIEEntry::getRefAddrSize(AP));
Eric Christopherdd508382014-03-06 00:00:56 +0000462 } else
David Blaikie8dbcc3f2014-04-25 19:33:43 +0000463 AP->EmitInt32(Entry.getOffset());
Bill Wendling47054f32009-05-15 00:11:17 +0000464}
465
Frederic Risscd044342015-03-04 02:30:08 +0000466unsigned DIEEntry::getRefAddrSize(const AsmPrinter *AP) {
Manman Renac8062b2013-07-02 23:40:10 +0000467 // DWARF4: References that use the attribute form DW_FORM_ref_addr are
468 // specified to be four bytes in the DWARF 32-bit format and eight bytes
469 // in the DWARF 64-bit format, while DWARF Version 2 specifies that such
470 // references have the same size as an address on the target system.
Timur Iskhodzhanov1cd14442013-12-03 15:10:23 +0000471 const DwarfDebug *DD = AP->getDwarfDebug();
472 assert(DD && "Expected Dwarf Debug info to be available");
473 if (DD->getDwarfVersion() == 2)
Manman Renac8062b2013-07-02 23:40:10 +0000474 return AP->getDataLayout().getPointerSize();
475 return sizeof(int32_t);
476}
477
Bill Wendling47054f32009-05-15 00:11:17 +0000478#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000479void DIEEntry::printImpl(raw_ostream &O) const {
David Blaikie8dbcc3f2014-04-25 19:33:43 +0000480 O << format("Die: 0x%lx", (long)(intptr_t)&Entry);
Bill Wendling47054f32009-05-15 00:11:17 +0000481}
482#endif
483
484//===----------------------------------------------------------------------===//
David Blaikie47f615e2013-12-17 23:32:35 +0000485// DIETypeSignature Implementation
486//===----------------------------------------------------------------------===//
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000487void DIETypeSignature::EmitValueImpl(const AsmPrinter *Asm, dwarf::Form Form) const {
David Blaikie47f615e2013-12-17 23:32:35 +0000488 assert(Form == dwarf::DW_FORM_ref_sig8);
Lang Hames9ff69c82015-04-24 19:11:51 +0000489 Asm->OutStreamer->EmitIntValue(Unit.getTypeSignature(), 8);
David Blaikie47f615e2013-12-17 23:32:35 +0000490}
491
492#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000493void DIETypeSignature::printImpl(raw_ostream &O) const {
David Blaikie47f615e2013-12-17 23:32:35 +0000494 O << format("Type Unit: 0x%lx", Unit.getTypeSignature());
495}
David Blaikie47f615e2013-12-17 23:32:35 +0000496#endif
497
498//===----------------------------------------------------------------------===//
Eric Christopher4a741042014-02-16 08:46:55 +0000499// DIELoc Implementation
500//===----------------------------------------------------------------------===//
501
502/// ComputeSize - calculate the size of the location expression.
503///
Frederic Risscd044342015-03-04 02:30:08 +0000504unsigned DIELoc::ComputeSize(const AsmPrinter *AP) const {
Eric Christopher8bdab432014-02-27 18:36:10 +0000505 if (!Size) {
506 const SmallVectorImpl<DIEAbbrevData> &AbbrevData = Abbrev.getData();
507 for (unsigned i = 0, N = Values.size(); i < N; ++i)
508 Size += Values[i]->SizeOf(AP, AbbrevData[i].getForm());
509 }
Eric Christopher4a741042014-02-16 08:46:55 +0000510
Eric Christopher8bdab432014-02-27 18:36:10 +0000511 return Size;
Eric Christopher4a741042014-02-16 08:46:55 +0000512}
513
514/// EmitValue - Emit location data.
515///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000516void DIELoc::EmitValueImpl(const AsmPrinter *Asm, dwarf::Form Form) const {
Eric Christopher4a741042014-02-16 08:46:55 +0000517 switch (Form) {
518 default: llvm_unreachable("Improper form for block");
519 case dwarf::DW_FORM_block1: Asm->EmitInt8(Size); break;
520 case dwarf::DW_FORM_block2: Asm->EmitInt16(Size); break;
521 case dwarf::DW_FORM_block4: Asm->EmitInt32(Size); break;
522 case dwarf::DW_FORM_block:
523 case dwarf::DW_FORM_exprloc:
524 Asm->EmitULEB128(Size); break;
525 }
526
527 const SmallVectorImpl<DIEAbbrevData> &AbbrevData = Abbrev.getData();
528 for (unsigned i = 0, N = Values.size(); i < N; ++i)
529 Values[i]->EmitValue(Asm, AbbrevData[i].getForm());
530}
531
532/// SizeOf - Determine size of location data in bytes.
533///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000534unsigned DIELoc::SizeOfImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Eric Christopher4a741042014-02-16 08:46:55 +0000535 switch (Form) {
536 case dwarf::DW_FORM_block1: return Size + sizeof(int8_t);
537 case dwarf::DW_FORM_block2: return Size + sizeof(int16_t);
538 case dwarf::DW_FORM_block4: return Size + sizeof(int32_t);
539 case dwarf::DW_FORM_block:
540 case dwarf::DW_FORM_exprloc:
Logan Chien5b776b72014-02-22 14:00:39 +0000541 return Size + getULEB128Size(Size);
Eric Christopher4a741042014-02-16 08:46:55 +0000542 default: llvm_unreachable("Improper form for block");
543 }
544}
545
546#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000547void DIELoc::printImpl(raw_ostream &O) const {
Eric Christopher4a741042014-02-16 08:46:55 +0000548 O << "ExprLoc: ";
549 DIE::print(O, 5);
550}
551#endif
552
553//===----------------------------------------------------------------------===//
Bill Wendling47054f32009-05-15 00:11:17 +0000554// DIEBlock Implementation
555//===----------------------------------------------------------------------===//
556
557/// ComputeSize - calculate the size of the block.
558///
Frederic Risscd044342015-03-04 02:30:08 +0000559unsigned DIEBlock::ComputeSize(const AsmPrinter *AP) const {
Eric Christopher8bdab432014-02-27 18:36:10 +0000560 if (!Size) {
561 const SmallVectorImpl<DIEAbbrevData> &AbbrevData = Abbrev.getData();
562 for (unsigned i = 0, N = Values.size(); i < N; ++i)
563 Size += Values[i]->SizeOf(AP, AbbrevData[i].getForm());
564 }
Bill Wendling47054f32009-05-15 00:11:17 +0000565
Eric Christopher8bdab432014-02-27 18:36:10 +0000566 return Size;
Bill Wendling47054f32009-05-15 00:11:17 +0000567}
568
569/// EmitValue - Emit block data.
570///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000571void DIEBlock::EmitValueImpl(const AsmPrinter *Asm, dwarf::Form Form) const {
Bill Wendling47054f32009-05-15 00:11:17 +0000572 switch (Form) {
Craig Topperee4dab52012-02-05 08:31:47 +0000573 default: llvm_unreachable("Improper form for block");
Chris Lattner9efd1182010-04-04 19:09:29 +0000574 case dwarf::DW_FORM_block1: Asm->EmitInt8(Size); break;
575 case dwarf::DW_FORM_block2: Asm->EmitInt16(Size); break;
576 case dwarf::DW_FORM_block4: Asm->EmitInt32(Size); break;
577 case dwarf::DW_FORM_block: Asm->EmitULEB128(Size); break;
Bill Wendling47054f32009-05-15 00:11:17 +0000578 }
579
Eric Christopher4887c8f2013-03-29 23:34:06 +0000580 const SmallVectorImpl<DIEAbbrevData> &AbbrevData = Abbrev.getData();
Chris Lattner3d72a672010-03-09 23:38:23 +0000581 for (unsigned i = 0, N = Values.size(); i < N; ++i)
Chris Lattner3a383cb2010-04-05 00:13:49 +0000582 Values[i]->EmitValue(Asm, AbbrevData[i].getForm());
Bill Wendling47054f32009-05-15 00:11:17 +0000583}
584
585/// SizeOf - Determine size of block data in bytes.
586///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000587unsigned DIEBlock::SizeOfImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Bill Wendling47054f32009-05-15 00:11:17 +0000588 switch (Form) {
589 case dwarf::DW_FORM_block1: return Size + sizeof(int8_t);
590 case dwarf::DW_FORM_block2: return Size + sizeof(int16_t);
591 case dwarf::DW_FORM_block4: return Size + sizeof(int32_t);
Logan Chien5b776b72014-02-22 14:00:39 +0000592 case dwarf::DW_FORM_block: return Size + getULEB128Size(Size);
David Blaikie46a9f012012-01-20 21:51:11 +0000593 default: llvm_unreachable("Improper form for block");
Bill Wendling47054f32009-05-15 00:11:17 +0000594 }
Bill Wendling47054f32009-05-15 00:11:17 +0000595}
596
Bill Wendling47054f32009-05-15 00:11:17 +0000597#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000598void DIEBlock::printImpl(raw_ostream &O) const {
Bill Wendling47054f32009-05-15 00:11:17 +0000599 O << "Blk: ";
600 DIE::print(O, 5);
601}
602#endif
Eric Christophera27220f2014-03-05 22:41:20 +0000603
604//===----------------------------------------------------------------------===//
605// DIELocList Implementation
606//===----------------------------------------------------------------------===//
607
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000608unsigned DIELocList::SizeOfImpl(const AsmPrinter *AP, dwarf::Form Form) const {
Eric Christophera27220f2014-03-05 22:41:20 +0000609 if (Form == dwarf::DW_FORM_data4)
610 return 4;
611 if (Form == dwarf::DW_FORM_sec_offset)
612 return 4;
613 return AP->getDataLayout().getPointerSize();
614}
615
616/// EmitValue - Emit label value.
617///
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000618void DIELocList::EmitValueImpl(const AsmPrinter *AP, dwarf::Form Form) const {
David Blaikie9c550ac2014-03-25 01:44:02 +0000619 DwarfDebug *DD = AP->getDwarfDebug();
Duncan P. N. Exon Smith364a3002015-04-17 21:34:47 +0000620 MCSymbol *Label = DD->getDebugLocs().getList(Index).Label;
Eric Christophera27220f2014-03-05 22:41:20 +0000621
David Blaikiee12ab122014-04-01 16:09:49 +0000622 if (AP->MAI->doesDwarfUseRelocationsAcrossSections() && !DD->useSplitDwarf())
Rafael Espindola063d7252015-03-10 16:58:10 +0000623 AP->emitSectionOffset(Label);
Eric Christophera27220f2014-03-05 22:41:20 +0000624 else
Rafael Espindola063d7252015-03-10 16:58:10 +0000625 AP->EmitLabelDifference(Label, Label->getSection().getBeginSymbol(), 4);
Eric Christophera27220f2014-03-05 22:41:20 +0000626}
627
628#ifndef NDEBUG
Duncan P. N. Exon Smith68b3f302015-05-23 01:45:07 +0000629void DIELocList::printImpl(raw_ostream &O) const {
Eric Christophera27220f2014-03-05 22:41:20 +0000630 O << "LocList: " << Index;
631
632}
633#endif