LLVM 23.0.0git
DwarfCompileUnit.cpp
Go to the documentation of this file.
1//===- llvm/CodeGen/DwarfCompileUnit.cpp - Dwarf Compile Units ------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file contains support for constructing a dwarf compile unit.
10//
11//===----------------------------------------------------------------------===//
12
13#include "DwarfCompileUnit.h"
14#include "AddressPool.h"
15#include "DwarfExpression.h"
16#include "llvm/ADT/STLExtras.h"
20#include "llvm/CodeGen/DIE.h"
26#include "llvm/IR/DataLayout.h"
27#include "llvm/IR/DebugInfo.h"
29#include "llvm/MC/MCAsmInfo.h"
30#include "llvm/MC/MCSection.h"
31#include "llvm/MC/MCStreamer.h"
32#include "llvm/MC/MCSymbol.h"
39#include <optional>
40#include <string>
41#include <utility>
42
43using namespace llvm;
44
45/// Query value using AddLinkageNamesToDeclCallOriginsForTuning.
47 "add-linkage-names-to-declaration-call-origins", cl::Hidden,
48 cl::desc("Add DW_AT_linkage_name to function declaration DIEs "
49 "referenced by DW_AT_call_origin attributes. Enabled by default "
50 "for -gsce debugger tuning."));
51
53 "emit-func-debug-line-table-offsets", cl::Hidden,
54 cl::desc("Include line table offset in function's debug info and emit end "
55 "sequence after each function's line data."),
56 cl::init(false));
57
59 bool EnabledByDefault = DD->tuneForSCE();
60 if (EnabledByDefault)
63}
64
66
67 // According to DWARF Debugging Information Format Version 5,
68 // 3.1.2 Skeleton Compilation Unit Entries:
69 // "When generating a split DWARF object file (see Section 7.3.2
70 // on page 187), the compilation unit in the .debug_info section
71 // is a "skeleton" compilation unit with the tag DW_TAG_skeleton_unit"
72 if (DW->getDwarfVersion() >= 5 && Kind == UnitKind::Skeleton)
73 return dwarf::DW_TAG_skeleton_unit;
74
75 return dwarf::DW_TAG_compile_unit;
76}
77
80 DwarfFile *DWU, UnitKind Kind)
81 : DwarfUnit(GetCompileUnitType(Kind, DW), Node, A, DW, DWU, UID) {
83 MacroLabelBegin = Asm->createTempSymbol("cu_macro_begin");
84}
85
86/// addLabelAddress - Add a dwarf label attribute data and value using
87/// DW_FORM_addr or DW_FORM_GNU_addr_index.
89 const MCSymbol *Label) {
90 if ((Skeleton || !DD->useSplitDwarf()) && Label)
91 DD->addArangeLabel(SymbolCU(this, Label));
92
93 // Don't use the address pool in non-fission or in the skeleton unit itself.
94 if ((!DD->useSplitDwarf() || !Skeleton) && DD->getDwarfVersion() < 5)
95 return addLocalLabelAddress(Die, Attribute, Label);
96
97 bool UseAddrOffsetFormOrExpressions =
98 DD->useAddrOffsetForm() || DD->useAddrOffsetExpressions();
99
100 const MCSymbol *Base = nullptr;
101 if (Label->isInSection() && UseAddrOffsetFormOrExpressions)
102 Base = DD->getSectionLabel(&Label->getSection());
103
104 if (!Base || Base == Label) {
105 unsigned idx = DD->getAddressPool().getIndex(Label);
107 DD->getDwarfVersion() >= 5 ? dwarf::DW_FORM_addrx
108 : dwarf::DW_FORM_GNU_addr_index,
109 DIEInteger(idx));
110 return;
111 }
112
113 // Could be extended to work with DWARFv4 Split DWARF if that's important for
114 // someone. In that case DW_FORM_data would be used.
115 assert(DD->getDwarfVersion() >= 5 &&
116 "Addr+offset expressions are only valuable when using debug_addr (to "
117 "reduce relocations) available in DWARFv5 or higher");
118 if (DD->useAddrOffsetExpressions()) {
119 auto *Loc = new (DIEValueAllocator) DIEBlock();
120 addPoolOpAddress(*Loc, Label);
121 addBlock(Die, Attribute, dwarf::DW_FORM_exprloc, Loc);
122 } else
123 addAttribute(Die, Attribute, dwarf::DW_FORM_LLVM_addrx_offset,
125 DD->getAddressPool().getIndex(Base), Label, Base));
126}
127
130 const MCSymbol *Label) {
131 if (Label)
132 addAttribute(Die, Attribute, dwarf::DW_FORM_addr, DIELabel(Label));
133 else
134 addAttribute(Die, Attribute, dwarf::DW_FORM_addr, DIEInteger(0));
135}
136
138 // If we print assembly, we can't separate .file entries according to
139 // compile units. Thus all files will belong to the default compile unit.
140
141 // FIXME: add a better feature test than hasRawTextSupport. Even better,
142 // extend .file to support this.
143 unsigned CUID = Asm->OutStreamer->hasRawTextSupport() ? 0 : getUniqueID();
144 if (!File)
145 return Asm->OutStreamer->emitDwarfFileDirective(0, "", "", std::nullopt,
146 std::nullopt, CUID);
147
148 if (LastFile != File) {
149 LastFile = File;
150 LastFileID = Asm->OutStreamer->emitDwarfFileDirective(
151 0, File->getDirectory(), File->getFilename(), DD->getMD5AsBytes(File),
152 File->getSource(), CUID);
153 }
154 return LastFileID;
155}
156
158 const DIGlobalVariable *GV, ArrayRef<GlobalExpr> GlobalExprs) {
159 // Check for pre-existence.
160 if (DIE *Die = getDIE(GV))
161 return Die;
162
163 assert(GV);
164
165 auto *GVContext = GV->getScope();
166 const DIType *GTy = GV->getType();
167
168 auto *CB = GVContext ? dyn_cast<DICommonBlock>(GVContext) : nullptr;
169 DIE *ContextDIE = CB ? getOrCreateCommonBlock(CB, GlobalExprs)
170 : getOrCreateContextDIE(GVContext);
171
172 // Add to map.
173 DIE *VariableDIE = &createAndAddDIE(GV->getTag(), *ContextDIE, GV);
175 if (auto *SDMDecl = GV->getStaticDataMemberDeclaration()) {
176 DeclContext = SDMDecl->getScope();
177 assert(SDMDecl->isStaticMember() && "Expected static member decl");
178 assert(GV->isDefinition());
179 // We need the declaration DIE that is in the static member's class.
180 DIE *VariableSpecDIE = getOrCreateStaticMemberDIE(SDMDecl);
181 addDIEEntry(*VariableDIE, dwarf::DW_AT_specification, *VariableSpecDIE);
182 // If the global variable's type is different from the one in the class
183 // member type, assume that it's more specific and also emit it.
184 if (GTy != SDMDecl->getBaseType())
185 addType(*VariableDIE, GTy);
186 } else {
187 DeclContext = GV->getScope();
188 // Add name and type.
189 StringRef DisplayName = GV->getDisplayName();
190 if (!DisplayName.empty())
191 addString(*VariableDIE, dwarf::DW_AT_name, GV->getDisplayName());
192 if (GTy)
193 addType(*VariableDIE, GTy);
194
195 // Add scoping info.
196 if (!GV->isLocalToUnit())
197 addFlag(*VariableDIE, dwarf::DW_AT_external);
198
199 // Add line number info.
200 addSourceLine(*VariableDIE, GV);
201 }
202
203 if (!GV->isDefinition())
204 addFlag(*VariableDIE, dwarf::DW_AT_declaration);
205 else
206 addGlobalName(GV->getName(), *VariableDIE, DeclContext);
207
208 addAnnotation(*VariableDIE, GV->getAnnotations());
209
210 if (uint32_t AlignInBytes = GV->getAlignInBytes())
211 addUInt(*VariableDIE, dwarf::DW_AT_alignment, dwarf::DW_FORM_udata,
212 AlignInBytes);
213
214 if (MDTuple *TP = GV->getTemplateParams())
215 addTemplateParams(*VariableDIE, DINodeArray(TP));
216
217 // Add location.
218 addLocationAttribute(VariableDIE, GV, GlobalExprs);
219
220 return VariableDIE;
221}
222
224 DIE *VariableDIE, const DIGlobalVariable *GV, ArrayRef<GlobalExpr> GlobalExprs) {
225 bool addToAccelTable = false;
226 DIELoc *Loc = nullptr;
227 std::optional<unsigned> TargetAddrSpace;
228 std::unique_ptr<DIEDwarfExpression> DwarfExpr;
229 const GlobalVariable *LastGlobal = nullptr;
230 for (const auto &GE : GlobalExprs) {
231 const GlobalVariable *Global = GE.Var;
232 const DIExpression *Expr = GE.Expr;
233
234 // For compatibility with DWARF 3 and earlier,
235 // DW_AT_location(DW_OP_constu, X, DW_OP_stack_value) or
236 // DW_AT_location(DW_OP_consts, X, DW_OP_stack_value) becomes
237 // DW_AT_const_value(X).
238 if (GlobalExprs.size() == 1 && Expr && Expr->isConstant()) {
239 addToAccelTable = true;
241 *VariableDIE,
243 *Expr->isConstant(),
244 Expr->getElement(1));
245 break;
246 }
247
248 // We cannot describe the location of dllimport'd variables: the
249 // computation of their address requires loads from the IAT.
250 if (Global && Global->hasDLLImportStorageClass())
251 continue;
252
253 // Nothing to describe without address or constant.
254 if (!Global && (!Expr || !Expr->isConstant()))
255 continue;
256
257 if (Global && Global->isThreadLocal() &&
258 !Asm->getObjFileLowering().supportDebugThreadLocalLocation())
259 continue;
260
261 if (!Loc) {
262 addToAccelTable = true;
264 DwarfExpr = std::make_unique<DIEDwarfExpression>(*Asm, *this, *Loc);
265 }
266
267 if (Expr) {
268 Expr = DD->adjustExpressionForTarget(Expr, TargetAddrSpace);
269 DwarfExpr->addFragmentOffset(Expr);
270 }
271
272 if (Global) {
273 const MCSymbol *Sym = Asm->getSymbol(Global);
274 // 16-bit platforms like MSP430 and AVR take this path, so sink this
275 // assert to platforms that use it.
276 auto GetPointerSizedFormAndOp = [this]() {
277 unsigned PointerSize = Asm->MAI->getCodePointerSize();
278 assert((PointerSize == 4 || PointerSize == 8) &&
279 "Add support for other sizes if necessary");
280 struct FormAndOp {
281 dwarf::Form Form;
283 };
284 return PointerSize == 4
285 ? FormAndOp{dwarf::DW_FORM_data4, dwarf::DW_OP_const4u}
286 : FormAndOp{dwarf::DW_FORM_data8, dwarf::DW_OP_const8u};
287 };
288 if (Global->isThreadLocal()) {
289 if (Asm->TM.getTargetTriple().isWasm()) {
290 // FIXME This is not guaranteed, but in practice, in static linking,
291 // if present, __tls_base's index is 1. This doesn't hold for dynamic
292 // linking, so TLS variables used in dynamic linking won't have
293 // correct debug info for now. See
294 // https://github.com/llvm/llvm-project/blob/19afbfe33156d211fa959dadeea46cd17b9c723c/lld/wasm/Driver.cpp#L786-L823
295 addWasmRelocBaseGlobal(Loc, "__tls_base", 1);
296 addOpAddress(*Loc, Sym);
297 addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_plus);
298 } else if (Asm->TM.useEmulatedTLS()) {
299 // TODO: add debug info for emulated thread local mode.
300 } else {
301 // FIXME: Make this work with -gsplit-dwarf.
302 // Based on GCC's support for TLS:
303 if (!DD->useSplitDwarf()) {
304 auto FormAndOp = GetPointerSizedFormAndOp();
305 // 1) Start with a constNu of the appropriate pointer size
306 addUInt(*Loc, dwarf::DW_FORM_data1, FormAndOp.Op);
307 // 2) containing the (relocated) offset of the TLS variable
308 // within the module's TLS block.
309 addExpr(*Loc, FormAndOp.Form,
310 Asm->getObjFileLowering().getDebugThreadLocalSymbol(Sym));
311 } else {
312 addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_GNU_const_index);
313 addUInt(*Loc, dwarf::DW_FORM_udata,
314 DD->getAddressPool().getIndex(Sym, /* TLS */ true));
315 }
316 // 3) followed by an OP to make the debugger do a TLS lookup.
317 addUInt(*Loc, dwarf::DW_FORM_data1,
318 DD->useGNUTLSOpcode() ? dwarf::DW_OP_GNU_push_tls_address
319 : dwarf::DW_OP_form_tls_address);
320 }
321 } else if (Asm->TM.getTargetTriple().isWasm() &&
322 Asm->TM.getRelocationModel() == Reloc::PIC_) {
323 // FIXME This is not guaranteed, but in practice, if present,
324 // __memory_base's index is 1. See
325 // https://github.com/llvm/llvm-project/blob/19afbfe33156d211fa959dadeea46cd17b9c723c/lld/wasm/Driver.cpp#L786-L823
326 addWasmRelocBaseGlobal(Loc, "__memory_base", 1);
327 addOpAddress(*Loc, Sym);
328 addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_plus);
329 } else if ((Asm->TM.getRelocationModel() == Reloc::RWPI ||
330 Asm->TM.getRelocationModel() == Reloc::ROPI_RWPI) &&
331 !Asm->getObjFileLowering()
332 .getKindForGlobal(Global, Asm->TM)
333 .isReadOnly()) {
334 auto FormAndOp = GetPointerSizedFormAndOp();
335 // Constant
336 addUInt(*Loc, dwarf::DW_FORM_data1, FormAndOp.Op);
337 // Relocation offset
338 addExpr(*Loc, FormAndOp.Form,
339 Asm->getObjFileLowering().getIndirectSymViaRWPI(Sym));
340 // Base register
341 Register BaseReg = Asm->getObjFileLowering().getStaticBase();
342 unsigned DwarfBaseReg =
343 Asm->TM.getMCRegisterInfo()->getDwarfRegNum(BaseReg, false);
344 addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_breg0 + DwarfBaseReg);
345 // Offset from base register
346 addSInt(*Loc, dwarf::DW_FORM_sdata, 0);
347 // Operation
348 addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_plus);
349 } else {
350 DD->addArangeLabel(SymbolCU(this, Sym));
351 addOpAddress(*Loc, Sym);
352 }
353 LastGlobal = Global;
354 }
355 // Global variables attached to symbols are memory locations.
356 // It would be better if this were unconditional, but malformed input that
357 // mixes non-fragments and fragments for the same variable is too expensive
358 // to detect in the verifier.
359 if (DwarfExpr->isUnknownLocation())
360 DwarfExpr->setMemoryLocationKind();
361 DwarfExpr->addExpression(Expr);
362 }
363 DD->addTargetVariableAttributes(*this, *VariableDIE, TargetAddrSpace,
365 LastGlobal);
366 if (Loc)
367 addBlock(*VariableDIE, dwarf::DW_AT_location, DwarfExpr->finalize());
368
369 if (DD->useAllLinkageNames())
370 addLinkageName(*VariableDIE, GV->getLinkageName());
371
372 if (addToAccelTable) {
373 DD->addAccelName(*this, CUNode->getNameTableKind(), GV->getName(),
374 *VariableDIE);
375
376 // If the linkage name is different than the name, go ahead and output
377 // that as well into the name table.
378 if (GV->getLinkageName() != "" && GV->getName() != GV->getLinkageName() &&
379 DD->useAllLinkageNames())
380 DD->addAccelName(*this, CUNode->getNameTableKind(), GV->getLinkageName(),
381 *VariableDIE);
382 }
383}
384
386 const DICommonBlock *CB, ArrayRef<GlobalExpr> GlobalExprs) {
387 // Check for pre-existence.
388 if (DIE *NDie = getDIE(CB))
389 return NDie;
390 DIE *ContextDIE = getOrCreateContextDIE(CB->getScope());
391 DIE &NDie = createAndAddDIE(dwarf::DW_TAG_common_block, *ContextDIE, CB);
392 StringRef Name = CB->getName().empty() ? "_BLNK_" : CB->getName();
393 addString(NDie, dwarf::DW_AT_name, Name);
394 addGlobalName(Name, NDie, CB->getScope());
395 if (CB->getFile())
396 addSourceLine(NDie, CB->getLineNo(), /*Column*/ 0, CB->getFile());
397 if (DIGlobalVariable *V = CB->getDecl())
398 getCU().addLocationAttribute(&NDie, V, GlobalExprs);
399 return &NDie;
400}
401
403 DD->insertSectionLabel(Range.Begin);
404
405 auto *PrevCU = DD->getPrevCU();
406 bool SameAsPrevCU = this == PrevCU;
407 DD->setPrevCU(this);
408 // If we have no current ranges just add the range and return, otherwise,
409 // check the current section and CU against the previous section and CU we
410 // emitted into and the subprogram was contained within. If these are the
411 // same then extend our current range, otherwise add this as a new range.
412 if (CURanges.empty() || !SameAsPrevCU ||
413 (&CURanges.back().End->getSection() !=
414 &Range.End->getSection())) {
415 // Before a new range is added, always terminate the prior line table.
416 if (PrevCU)
417 DD->terminateLineTable(PrevCU);
418 CURanges.push_back(Range);
419 return;
420 }
421
422 CURanges.back().End = Range.End;
423}
424
426 if (CUNode->isDebugDirectivesOnly())
427 return;
428
429 const TargetLoweringObjectFile &TLOF = Asm->getObjFileLowering();
430 if (DD->useSectionsAsReferences()) {
431 LineTableStartSym = TLOF.getDwarfLineSection()->getBeginSymbol();
432 } else {
433 LineTableStartSym =
434 Asm->OutStreamer->getDwarfLineTableSymbol(getUniqueID());
435 }
436
437 // DW_AT_stmt_list is a offset of line number information for this
438 // compile unit in debug_line section. For split dwarf this is
439 // left in the skeleton CU and so not included.
440 // The line table entries are not always emitted in assembly, so it
441 // is not okay to use line_table_start here.
442 addSectionLabel(getUnitDie(), dwarf::DW_AT_stmt_list, LineTableStartSym,
444}
445
447 const TargetLoweringObjectFile &TLOF = Asm->getObjFileLowering();
448 addSectionLabel(D, dwarf::DW_AT_stmt_list, LineTableStartSym,
450}
451
453 const MCSymbol *End) {
454 assert(Begin && "Begin label should not be null!");
455 assert(End && "End label should not be null!");
456 assert(Begin->isDefined() && "Invalid starting label");
457 assert(End->isDefined() && "Invalid end label");
458
459 addLabelAddress(D, dwarf::DW_AT_low_pc, Begin);
460 if (DD->getDwarfVersion() >= 4 &&
461 (!isDwoUnit() || !llvm::isRangeRelaxable(Begin, End))) {
462 addLabelDelta(D, dwarf::DW_AT_high_pc, End, Begin);
463 return;
464 }
465 addLabelAddress(D, dwarf::DW_AT_high_pc, End);
466}
467
468// Add info for Wasm-global-based relocation.
469// 'GlobalIndex' is used for split dwarf, which currently relies on a few
470// assumptions that are not guaranteed in a formal way but work in practice.
471void DwarfCompileUnit::addWasmRelocBaseGlobal(DIELoc *Loc, StringRef GlobalName,
472 uint64_t GlobalIndex) {
473 // FIXME: duplicated from Target/WebAssembly/WebAssembly.h
474 // don't want to depend on target specific headers in this code?
475 const unsigned TI_GLOBAL_RELOC = 3;
476 unsigned PointerSize = Asm->getDataLayout().getPointerSize();
477 auto *Sym =
478 static_cast<MCSymbolWasm *>(Asm->GetExternalSymbolSymbol(GlobalName));
479 // FIXME: this repeats what WebAssemblyMCInstLower::
480 // GetExternalSymbolSymbol does, since if there's no code that
481 // refers to this symbol, we have to set it here.
483 Sym->setGlobalType(wasm::WasmGlobalType{
484 static_cast<uint8_t>(PointerSize == 4 ? wasm::WASM_TYPE_I32
486 true});
487 addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_WASM_location);
488 addSInt(*Loc, dwarf::DW_FORM_sdata, TI_GLOBAL_RELOC);
489 if (!isDwoUnit()) {
490 addLabel(*Loc, dwarf::DW_FORM_data4, Sym);
491 } else {
492 // FIXME: when writing dwo, we need to avoid relocations. Probably
493 // the "right" solution is to treat globals the way func and data
494 // symbols are (with entries in .debug_addr).
495 // For now we hardcode the indices in the callsites. Global indices are not
496 // fixed, but in practice a few are fixed; for example, __stack_pointer is
497 // always index 0.
498 addUInt(*Loc, dwarf::DW_FORM_data4, GlobalIndex);
499 }
500}
501
502// Find DIE for the given subprogram and attach appropriate DW_AT_low_pc
503// and DW_AT_high_pc attributes. If there are global variables in this
504// scope then create and insert DIEs for these variables.
506 const Function &F,
507 MCSymbol *LineTableSym) {
510 // If basic block sections are on, ranges for each basic block section has
511 // to be emitted separately.
512 for (const auto &R : Asm->MBBSectionRanges)
513 BB_List.push_back({R.second.BeginLabel, R.second.EndLabel});
514
515 attachRangesOrLowHighPC(*SPDie, BB_List);
516
517 if (DD->useAppleExtensionAttributes() &&
518 !DD->getCurrentFunction()->getTarget().Options.DisableFramePointerElim(
519 *DD->getCurrentFunction()))
520 addFlag(*SPDie, dwarf::DW_AT_APPLE_omit_frame_ptr);
521
522 if (emitFuncLineTableOffsets() && LineTableSym) {
524 *SPDie, dwarf::DW_AT_LLVM_stmt_sequence, LineTableSym,
525 Asm->getObjFileLowering().getDwarfLineSection()->getBeginSymbol());
526 }
527
528 // Only include DW_AT_frame_base in full debug info
530 const TargetFrameLowering *TFI = Asm->MF->getSubtarget().getFrameLowering();
532 TFI->getDwarfFrameBase(*Asm->MF);
533 switch (FrameBase.Kind) {
536 MachineLocation Location(FrameBase.Location.Reg);
537 addAddress(*SPDie, dwarf::DW_AT_frame_base, Location);
538 }
539 break;
540 }
543 addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_call_frame_cfa);
544 if (FrameBase.Location.Offset != 0) {
545 addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_consts);
546 addSInt(*Loc, dwarf::DW_FORM_sdata, FrameBase.Location.Offset);
547 addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_plus);
548 }
549 addBlock(*SPDie, dwarf::DW_AT_frame_base, Loc);
550 break;
551 }
553 // FIXME: duplicated from Target/WebAssembly/WebAssembly.h
554 const unsigned TI_GLOBAL_RELOC = 3;
555 if (FrameBase.Location.WasmLoc.Kind == TI_GLOBAL_RELOC) {
556 // These need to be relocatable.
558 assert(FrameBase.Location.WasmLoc.Index == 0); // Only SP so far.
559 // For now, since we only ever use index 0, this should work as-is.
560 addWasmRelocBaseGlobal(Loc, "__stack_pointer",
561 FrameBase.Location.WasmLoc.Index);
562 addUInt(*Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_stack_value);
563 addBlock(*SPDie, dwarf::DW_AT_frame_base, Loc);
564 } else {
566 DIEDwarfExpression DwarfExpr(*Asm, *this, *Loc);
567 DIExpressionCursor Cursor({});
568 DwarfExpr.addWasmLocation(FrameBase.Location.WasmLoc.Kind,
569 FrameBase.Location.WasmLoc.Index);
570 DwarfExpr.addExpression(std::move(Cursor));
571 addBlock(*SPDie, dwarf::DW_AT_frame_base, DwarfExpr.finalize());
572 }
573 break;
574 }
575 }
576 }
577
578 // Add name to the name table, we do this here because we're guaranteed
579 // to have concrete versions of our DW_TAG_subprogram nodes.
580 DD->addSubprogramNames(*this, CUNode->getNameTableKind(), SP, *SPDie);
581
582 return *SPDie;
583}
584
585// Construct a DIE for this scope.
587 DIE &ParentScopeDIE) {
588 if (!Scope || !Scope->getScopeNode())
589 return;
590
591 auto *DS = Scope->getScopeNode();
592
593 assert((Scope->getInlinedAt() || !isa<DISubprogram>(DS)) &&
594 "Only handle inlined subprograms here, use "
595 "constructSubprogramScopeDIE for non-inlined "
596 "subprograms");
597
598 // Emit inlined subprograms.
599 if (Scope->getParent() && isa<DISubprogram>(DS)) {
600 DIE *ScopeDIE = constructInlinedScopeDIE(Scope, ParentScopeDIE);
601 assert(ScopeDIE && "Scope DIE should not be null.");
602 createAndAddScopeChildren(Scope, *ScopeDIE);
603 return;
604 }
605
606 // Early exit when we know the scope DIE is going to be null.
607 if (DD->isLexicalScopeDIENull(Scope))
608 return;
609
610 // Emit lexical blocks.
611 DIE *ScopeDIE = getOrCreateLexicalBlockDIE(Scope, ParentScopeDIE);
612 assert(ScopeDIE && "Scope DIE should not be null.");
613
614 createAndAddScopeChildren(Scope, *ScopeDIE);
615}
616
619
620 HasRangeLists = true;
621
622 // Add the range list to the set of ranges to be emitted.
623 auto IndexAndList =
624 (DD->getDwarfVersion() < 5 && Skeleton ? Skeleton->DU : DU)
625 ->addRange(*(Skeleton ? Skeleton : this), std::move(Range));
626
627 uint32_t Index = IndexAndList.first;
628 auto &List = *IndexAndList.second;
629
630 // Under fission, ranges are specified by constant offsets relative to the
631 // CU's DW_AT_GNU_ranges_base.
632 // FIXME: For DWARF v5, do not generate the DW_AT_ranges attribute under
633 // fission until we support the forms using the .debug_addr section
634 // (DW_RLE_startx_endx etc.).
635 if (DD->getDwarfVersion() >= 5)
636 addUInt(ScopeDIE, dwarf::DW_AT_ranges, dwarf::DW_FORM_rnglistx, Index);
637 else {
638 const TargetLoweringObjectFile &TLOF = Asm->getObjFileLowering();
639 const MCSymbol *RangeSectionSym =
641 if (isDwoUnit())
642 addSectionDelta(ScopeDIE, dwarf::DW_AT_ranges, List.Label,
643 RangeSectionSym);
644 else
645 addSectionLabel(ScopeDIE, dwarf::DW_AT_ranges, List.Label,
646 RangeSectionSym);
647 }
648}
649
651 DIE &Die, SmallVector<RangeSpan, 2> Ranges) {
652 assert(!Ranges.empty());
653 if (!DD->useRangesSection() ||
654 (Ranges.size() == 1 &&
655 (!DD->alwaysUseRanges(*this) ||
656 DD->getSectionLabel(&Ranges.front().Begin->getSection()) ==
657 Ranges.front().Begin))) {
658 const RangeSpan &Front = Ranges.front();
659 const RangeSpan &Back = Ranges.back();
660 attachLowHighPC(Die, Front.Begin, Back.End);
661 } else
662 addScopeRangeList(Die, std::move(Ranges));
663}
664
666 DIE &Die, const SmallVectorImpl<InsnRange> &Ranges) {
668 List.reserve(Ranges.size());
669 for (const InsnRange &R : Ranges) {
670 auto *BeginLabel = DD->getLabelBeforeInsn(R.first);
671 auto *EndLabel = DD->getLabelAfterInsn(R.second);
672
673 const auto *BeginMBB = R.first->getParent();
674 const auto *EndMBB = R.second->getParent();
675
676 const auto *MBB = BeginMBB;
677 // Basic block sections allows basic block subsets to be placed in unique
678 // sections. For each section, the begin and end label must be added to the
679 // list. If there is more than one range, debug ranges must be used.
680 // Otherwise, low/high PC can be used.
681 // FIXME: Debug Info Emission depends on block order and this assumes that
682 // the order of blocks will be frozen beyond this point.
683 do {
684 if (MBB->sameSection(EndMBB) || MBB->isEndSection()) {
685 auto MBBSectionRange = Asm->MBBSectionRanges[MBB->getSectionID()];
686 List.push_back(
687 {MBB->sameSection(BeginMBB) ? BeginLabel
688 : MBBSectionRange.BeginLabel,
689 MBB->sameSection(EndMBB) ? EndLabel : MBBSectionRange.EndLabel});
690 }
691 if (MBB->sameSection(EndMBB))
692 break;
693 MBB = MBB->getNextNode();
694 } while (true);
695 }
696 attachRangesOrLowHighPC(Die, std::move(List));
697}
698
700 DIE &ParentScopeDIE) {
701 assert(Scope->getScopeNode());
702 auto *DS = Scope->getScopeNode();
703 auto *InlinedSP = getDISubprogram(DS);
704 // Find the subprogram's DwarfCompileUnit in the SPMap in case the subprogram
705 // was inlined from another compile unit.
706 DIE *OriginDIE = getAbstractScopeDIEs()[InlinedSP];
707 assert(OriginDIE && "Unable to find original DIE for an inlined subprogram.");
708
709 auto ScopeDIE = DIE::get(DIEValueAllocator, dwarf::DW_TAG_inlined_subroutine);
710 ParentScopeDIE.addChild(ScopeDIE);
711 addDIEEntry(*ScopeDIE, dwarf::DW_AT_abstract_origin, *OriginDIE);
712
713 attachRangesOrLowHighPC(*ScopeDIE, Scope->getRanges());
714
715 // Add the call site information to the DIE.
716 const DILocation *IA = Scope->getInlinedAt();
717 addUInt(*ScopeDIE, dwarf::DW_AT_call_file, std::nullopt,
718 getOrCreateSourceID(IA->getFile()));
719 addUInt(*ScopeDIE, dwarf::DW_AT_call_line, std::nullopt, IA->getLine());
720 if (IA->getColumn())
721 addUInt(*ScopeDIE, dwarf::DW_AT_call_column, std::nullopt, IA->getColumn());
722 if (IA->getDiscriminator() && DD->getDwarfVersion() >= 4)
723 addUInt(*ScopeDIE, dwarf::DW_AT_GNU_discriminator, std::nullopt,
724 IA->getDiscriminator());
725
726 // Add name to the name table, we do this here because we're guaranteed
727 // to have concrete versions of our DW_TAG_inlined_subprogram nodes.
728 DD->addSubprogramNames(*this, CUNode->getNameTableKind(), InlinedSP,
729 *ScopeDIE);
730
731 return ScopeDIE;
732}
733
735 DIE &ParentScopeDIE) {
736 if (DD->isLexicalScopeDIENull(Scope))
737 return nullptr;
738 const auto *DS = Scope->getScopeNode();
739
740 auto ScopeDIE = DIE::get(DIEValueAllocator, dwarf::DW_TAG_lexical_block);
741 ParentScopeDIE.addChild(ScopeDIE);
742
743 if (Scope->isAbstractScope()) {
744 assert(!getAbstractScopeDIEs().count(DS) &&
745 "Abstract DIE for this scope exists!");
746 getAbstractScopeDIEs()[DS] = ScopeDIE;
747 return ScopeDIE;
748 }
749 if (!Scope->getInlinedAt()) {
750 assert(!LexicalBlockDIEs.count(DS) &&
751 "Concrete out-of-line DIE for this scope exists!");
752 LexicalBlockDIEs[DS] = ScopeDIE;
753 } else {
754 InlinedLocalScopeDIEs[DS].push_back(ScopeDIE);
755 }
756
757 attachRangesOrLowHighPC(*ScopeDIE, Scope->getRanges());
758
759 return ScopeDIE;
760}
761
763 auto *VariableDie = DIE::get(DIEValueAllocator, DV.getTag());
764 insertDIE(DV.getVariable(), VariableDie);
765 DV.setDIE(*VariableDie);
766 // Abstract variables don't get common attributes later, so apply them now.
767 if (Abstract) {
768 applyCommonDbgVariableAttributes(DV, *VariableDie);
769 } else {
770 std::visit(
771 [&](const auto &V) {
772 applyConcreteDbgVariableAttributes(V, DV, *VariableDie);
773 },
774 DV.asVariant());
775 }
776 return VariableDie;
777}
778
779static const DIType *resolveTypeQualifiers(const DIType *Ty) {
780 while (const auto *DT = dyn_cast_or_null<DIDerivedType>(Ty)) {
781 switch (DT->getTag()) {
782 case dwarf::DW_TAG_typedef:
783 case dwarf::DW_TAG_const_type:
784 case dwarf::DW_TAG_volatile_type:
785 case dwarf::DW_TAG_restrict_type:
786 case dwarf::DW_TAG_atomic_type:
787 Ty = DT->getBaseType();
788 continue;
789 default:
790 return Ty;
791 }
792 }
793 return Ty;
794}
795
796bool DwarfCompileUnit::emitImplicitPointerLocation(const Loc::Single &Single,
797 const DbgVariable &DV,
798 DIE &VariableDie) {
799 const DIExpression *Expr = Single.getExpr();
800 if (!Expr)
801 return false;
802
803 // Only handle the simple case where DW_OP_LLVM_implicit_pointer is the
804 // sole operation (or followed only by DW_OP_LLVM_fragment).
805 //
806 // Multi-level implicit pointers (e.g., int **pp where both levels are
807 // optimized away) would require stacking multiple implicit_pointer ops
808 // in one expression and unwinding them into a chain of artificial DIEs.
809 // This is left for future work.
810 //
811 // Location list support (Loc::Multi) is not yet handled.
812 auto ExprOps = Expr->expr_ops();
813 auto FirstOp = ExprOps.begin();
814 if (FirstOp == ExprOps.end() ||
815 FirstOp->getOp() != dwarf::DW_OP_LLVM_implicit_pointer)
816 return false;
817
818 if (DD->getDwarfVersion() < 4)
819 return false;
820
821 const DbgValueLoc &DVal = Single.getValueLoc();
822 if (DVal.isVariadic())
823 return false;
824
825 assert(!DVal.getLocEntries().empty() &&
826 "Non-variadic value must have one entry");
827 const DbgValueLocEntry &Entry = DVal.getLocEntries()[0];
828
829 // Resolve the variable's type, stripping qualifiers and typedefs,
830 // to find the pointer or reference type underneath.
831 // The verifier rejects cyclic type references, so this loop terminates.
832 const DIDerivedType *PtrTy =
834 if (!PtrTy)
835 return false;
836
837 if (PtrTy->getTag() != dwarf::DW_TAG_pointer_type &&
838 PtrTy->getTag() != dwarf::DW_TAG_reference_type &&
839 PtrTy->getTag() != dwarf::DW_TAG_rvalue_reference_type)
840 return false;
841
842 const DIType *PointeeTy = PtrTy->getBaseType();
843
844 // Try to reuse an existing artificial DIE for constant integer values.
845 // This avoids duplicate DIEs when multiple pointer variables reference
846 // the same constant (e.g., after ArgumentPromotion promotes the same
847 // struct member for two different pointer parameters).
848 DIE *ArtificialDIEPtr = nullptr;
849 if (Entry.isInt() && PointeeTy) {
850 auto It = ImplicitPointerDIEs.find({PointeeTy, Entry.getInt()});
851 if (It != ImplicitPointerDIEs.end())
852 ArtificialDIEPtr = It->second;
853 }
854
855 if (!ArtificialDIEPtr) {
856 DIE &ProcDIE = createAndAddDIE(dwarf::DW_TAG_dwarf_procedure, getUnitDie());
857
858 if (Entry.isLocation()) {
859 addAddress(ProcDIE, dwarf::DW_AT_location, Entry.getLoc());
860 } else if (Entry.isInt()) {
861 if (PointeeTy)
862 addConstantValue(ProcDIE, Entry.getInt(), PointeeTy);
863 } else if (Entry.isConstantFP()) {
864 addConstantFPValue(ProcDIE, Entry.getConstantFP());
865 } else {
866 return false;
867 }
868
869 ArtificialDIEPtr = &ProcDIE;
870
871 // Cache constant entries for de-duplication.
872 if (Entry.isInt() && PointeeTy)
873 ImplicitPointerDIEs.insert(
874 {{PointeeTy, Entry.getInt()}, ArtificialDIEPtr});
875 }
876
877 auto *Loc = new (DIEValueAllocator) DIELoc;
878
879 const unsigned ImplicitPtrOp = DD->getDwarfVersion() >= 5
880 ? dwarf::DW_OP_implicit_pointer
881 : dwarf::DW_OP_GNU_implicit_pointer;
882 addUInt(*Loc, dwarf::DW_FORM_data1, ImplicitPtrOp);
883
884 Loc->addValue(DIEValueAllocator, static_cast<dwarf::Attribute>(0),
885 dwarf::DW_FORM_ref_addr, DIEEntry(*ArtificialDIEPtr));
886
887 addSInt(*Loc, dwarf::DW_FORM_sdata, 0);
888
889 addBlock(VariableDie, dwarf::DW_AT_location, Loc);
890 return true;
891}
892
893void DwarfCompileUnit::applyConcreteDbgVariableAttributes(
894 const Loc::Single &Single, const DbgVariable &DV, DIE &VariableDie) {
895 // Handle DW_OP_LLVM_implicit_pointer before normal location emission.
896 if (emitImplicitPointerLocation(Single, DV, VariableDie))
897 return;
898
899 const DbgValueLoc *DVal = &Single.getValueLoc();
900 if (!Single.getExpr())
901 DD->addTargetVariableAttributes(*this, VariableDie, std::nullopt,
903 if (!DVal->isVariadic()) {
904 const DbgValueLocEntry *Entry = DVal->getLocEntries().begin();
905 if (Entry->isLocation()) {
906 addVariableAddress(DV, VariableDie, Entry->getLoc());
907 } else if (Entry->isInt()) {
908 auto *Expr = Single.getExpr();
909 if (Expr && Expr->getNumElements()) {
910 DIELoc *Loc = new (DIEValueAllocator) DIELoc;
911 DIEDwarfExpression DwarfExpr(*Asm, *this, *Loc);
912 // If there is an expression, emit raw unsigned bytes.
913 DwarfExpr.addFragmentOffset(Expr);
914 DwarfExpr.addUnsignedConstant(Entry->getInt());
915 DwarfExpr.addExpression(Expr);
916 addBlock(VariableDie, dwarf::DW_AT_location, DwarfExpr.finalize());
917 if (DwarfExpr.TagOffset)
918 addUInt(VariableDie, dwarf::DW_AT_LLVM_tag_offset,
919 dwarf::DW_FORM_data1, *DwarfExpr.TagOffset);
920 } else
921 addConstantValue(VariableDie, Entry->getInt(), DV.getType());
922 } else if (Entry->isConstantFP()) {
923 addConstantFPValue(VariableDie, Entry->getConstantFP());
924 } else if (Entry->isConstantInt()) {
925 addConstantValue(VariableDie, Entry->getConstantInt(), DV.getType());
926 } else if (Entry->isTargetIndexLocation()) {
927 DIELoc *Loc = new (DIEValueAllocator) DIELoc;
928 DIEDwarfExpression DwarfExpr(*Asm, *this, *Loc);
929 const DIBasicType *BT = dyn_cast<DIBasicType>(
930 static_cast<const Metadata *>(DV.getVariable()->getType()));
931 DwarfDebug::emitDebugLocValue(*Asm, BT, *DVal, DwarfExpr);
932 addBlock(VariableDie, dwarf::DW_AT_location, DwarfExpr.finalize());
933 }
934 return;
935 }
936 // If any of the location entries are registers with the value 0,
937 // then the location is undefined.
938 if (any_of(DVal->getLocEntries(), [](const DbgValueLocEntry &Entry) {
939 return Entry.isLocation() && !Entry.getLoc().getReg();
940 }))
941 return;
942 const DIExpression *Expr = Single.getExpr();
943 assert(Expr && "Variadic Debug Value must have an Expression.");
944 DIELoc *Loc = new (DIEValueAllocator) DIELoc;
945 DIEDwarfExpression DwarfExpr(*Asm, *this, *Loc);
946 DwarfExpr.addFragmentOffset(Expr);
947 DIExpressionCursor Cursor(Expr);
948 const TargetRegisterInfo &TRI = *Asm->MF->getSubtarget().getRegisterInfo();
949
950 auto AddEntry = [&](const DbgValueLocEntry &Entry,
951 DIExpressionCursor &Cursor) {
952 if (Entry.isLocation()) {
953 if (!DwarfExpr.addMachineRegExpression(TRI, Cursor,
954 Entry.getLoc().getReg()))
955 return false;
956 } else if (Entry.isInt()) {
957 // If there is an expression, emit raw unsigned bytes.
958 DwarfExpr.addUnsignedConstant(Entry.getInt());
959 } else if (Entry.isConstantFP()) {
960 // DwarfExpression does not support arguments wider than 64 bits
961 // (see PR52584).
962 // TODO: Consider chunking expressions containing overly wide
963 // arguments into separate pointer-sized fragment expressions.
964 APInt RawBytes = Entry.getConstantFP()->getValueAPF().bitcastToAPInt();
965 if (RawBytes.getBitWidth() > 64)
966 return false;
967 DwarfExpr.addUnsignedConstant(RawBytes.getZExtValue());
968 } else if (Entry.isConstantInt()) {
969 APInt RawBytes = Entry.getConstantInt()->getValue();
970 if (RawBytes.getBitWidth() > 64)
971 return false;
972 DwarfExpr.addUnsignedConstant(RawBytes.getZExtValue());
973 } else if (Entry.isTargetIndexLocation()) {
974 TargetIndexLocation Loc = Entry.getTargetIndexLocation();
975 // TODO TargetIndexLocation is a target-independent. Currently
976 // only the WebAssembly-specific encoding is supported.
977 assert(Asm->TM.getTargetTriple().isWasm());
978 DwarfExpr.addWasmLocation(Loc.Index, static_cast<uint64_t>(Loc.Offset));
979 } else {
980 llvm_unreachable("Unsupported Entry type.");
981 }
982 return true;
983 };
984
985 if (!DwarfExpr.addExpression(
986 std::move(Cursor),
987 [&](unsigned Idx, DIExpressionCursor &Cursor) -> bool {
988 return AddEntry(DVal->getLocEntries()[Idx], Cursor);
989 }))
990 return;
991
992 // Now attach the location information to the DIE.
993 addBlock(VariableDie, dwarf::DW_AT_location, DwarfExpr.finalize());
994 if (DwarfExpr.TagOffset)
995 addUInt(VariableDie, dwarf::DW_AT_LLVM_tag_offset, dwarf::DW_FORM_data1,
996 *DwarfExpr.TagOffset);
997}
998
999void DwarfCompileUnit::applyConcreteDbgVariableAttributes(
1000 const Loc::Multi &Multi, const DbgVariable &DV, DIE &VariableDie) {
1001 addLocationList(VariableDie, dwarf::DW_AT_location,
1002 Multi.getDebugLocListIndex());
1003 auto TagOffset = Multi.getDebugLocListTagOffset();
1004 if (TagOffset)
1005 addUInt(VariableDie, dwarf::DW_AT_LLVM_tag_offset, dwarf::DW_FORM_data1,
1006 *TagOffset);
1007}
1008
1009void DwarfCompileUnit::applyConcreteDbgVariableAttributes(const Loc::MMI &MMI,
1010 const DbgVariable &DV,
1011 DIE &VariableDie) {
1012 std::optional<unsigned> TargetAddrSpace;
1013 DIELoc *Loc = new (DIEValueAllocator) DIELoc;
1014 DIEDwarfExpression DwarfExpr(*Asm, *this, *Loc);
1015 for (const auto &Fragment : MMI.getFrameIndexExprs()) {
1016 Register FrameReg;
1017 const DIExpression *Expr = Fragment.Expr;
1018 const TargetFrameLowering *TFI = Asm->MF->getSubtarget().getFrameLowering();
1019 StackOffset Offset =
1020 TFI->getFrameIndexReference(*Asm->MF, Fragment.FI, FrameReg);
1021 DwarfExpr.addFragmentOffset(Expr);
1022
1023 auto *TRI = Asm->MF->getSubtarget().getRegisterInfo();
1024 SmallVector<uint64_t, 8> Ops;
1025 TRI->getOffsetOpcodes(Offset, Ops);
1026
1027 Expr = DD->adjustExpressionForTarget(Expr, TargetAddrSpace);
1028 if (Expr)
1029 Ops.append(Expr->elements_begin(), Expr->elements_end());
1030 DIExpressionCursor Cursor(Ops);
1031 DwarfExpr.setMemoryLocationKind();
1032 if (const MCSymbol *FrameSymbol = Asm->getFunctionFrameSymbol())
1033 addOpAddress(*Loc, FrameSymbol);
1034 else
1035 DwarfExpr.addMachineRegExpression(
1036 *Asm->MF->getSubtarget().getRegisterInfo(), Cursor, FrameReg);
1037 DwarfExpr.addExpression(std::move(Cursor));
1038 }
1039 DD->addTargetVariableAttributes(*this, VariableDie, TargetAddrSpace,
1041 addBlock(VariableDie, dwarf::DW_AT_location, DwarfExpr.finalize());
1042 if (DwarfExpr.TagOffset)
1043 addUInt(VariableDie, dwarf::DW_AT_LLVM_tag_offset, dwarf::DW_FORM_data1,
1044 *DwarfExpr.TagOffset);
1045}
1046
1047void DwarfCompileUnit::applyConcreteDbgVariableAttributes(
1048 const Loc::EntryValue &EntryValue, const DbgVariable &DV,
1049 DIE &VariableDie) {
1050 DIELoc *Loc = new (DIEValueAllocator) DIELoc;
1051 DIEDwarfExpression DwarfExpr(*Asm, *this, *Loc);
1052 // Emit each expression as: EntryValue(Register) <other ops> <Fragment>.
1053 for (auto [Register, Expr] : EntryValue.EntryValues) {
1054 DwarfExpr.addFragmentOffset(&Expr);
1055 DIExpressionCursor Cursor(Expr.getElements());
1056 DwarfExpr.beginEntryValueExpression(Cursor);
1057 DwarfExpr.addMachineRegExpression(
1058 *Asm->MF->getSubtarget().getRegisterInfo(), Cursor, Register);
1059 DwarfExpr.addExpression(std::move(Cursor));
1060 }
1061 addBlock(VariableDie, dwarf::DW_AT_location, DwarfExpr.finalize());
1062}
1063
1064void DwarfCompileUnit::applyConcreteDbgVariableAttributes(
1065 const std::monostate &, const DbgVariable &DV, DIE &VariableDie) {}
1066
1068 const LexicalScope &Scope,
1069 DIE *&ObjectPointer) {
1070 auto Var = constructVariableDIE(DV, Scope.isAbstractScope());
1071 if (DV.isObjectPointer())
1072 ObjectPointer = Var;
1073 return Var;
1074}
1075
1077 const LexicalScope &Scope) {
1078 auto LabelDie = DIE::get(DIEValueAllocator, DL.getTag());
1079 insertDIE(DL.getLabel(), LabelDie);
1080 DL.setDIE(*LabelDie);
1081
1082 if (Scope.isAbstractScope())
1083 applyLabelAttributes(DL, *LabelDie);
1084
1085 return LabelDie;
1086}
1087
1088/// Return all DIVariables that appear in count: expressions.
1091 auto *Array = dyn_cast<DICompositeType>(Var->getType());
1092 if (!Array || Array->getTag() != dwarf::DW_TAG_array_type)
1093 return Result;
1094 if (auto *DLVar = Array->getDataLocation())
1095 Result.push_back(DLVar);
1096 if (auto *AsVar = Array->getAssociated())
1097 Result.push_back(AsVar);
1098 if (auto *AlVar = Array->getAllocated())
1099 Result.push_back(AlVar);
1100 for (auto *El : Array->getElements()) {
1101 if (auto *Subrange = dyn_cast<DISubrange>(El)) {
1102 if (auto Count = Subrange->getCount())
1103 if (auto *Dependency = dyn_cast_if_present<DIVariable *>(Count))
1104 Result.push_back(Dependency);
1105 if (auto LB = Subrange->getLowerBound())
1106 if (auto *Dependency = dyn_cast_if_present<DIVariable *>(LB))
1107 Result.push_back(Dependency);
1108 if (auto UB = Subrange->getUpperBound())
1109 if (auto *Dependency = dyn_cast_if_present<DIVariable *>(UB))
1110 Result.push_back(Dependency);
1111 if (auto ST = Subrange->getStride())
1112 if (auto *Dependency = dyn_cast_if_present<DIVariable *>(ST))
1113 Result.push_back(Dependency);
1114 } else if (auto *GenericSubrange = dyn_cast<DIGenericSubrange>(El)) {
1115 if (auto Count = GenericSubrange->getCount())
1116 if (auto *Dependency = dyn_cast_if_present<DIVariable *>(Count))
1117 Result.push_back(Dependency);
1118 if (auto LB = GenericSubrange->getLowerBound())
1119 if (auto *Dependency = dyn_cast_if_present<DIVariable *>(LB))
1120 Result.push_back(Dependency);
1121 if (auto UB = GenericSubrange->getUpperBound())
1122 if (auto *Dependency = dyn_cast_if_present<DIVariable *>(UB))
1123 Result.push_back(Dependency);
1124 if (auto ST = GenericSubrange->getStride())
1125 if (auto *Dependency = dyn_cast_if_present<DIVariable *>(ST))
1126 Result.push_back(Dependency);
1127 }
1128 }
1129 return Result;
1130}
1131
1132/// Sort local variables so that variables appearing inside of helper
1133/// expressions come first.
1138 // Map back from a DIVariable to its containing DbgVariable.
1140 // Set of DbgVariables in Result.
1142 // For cycle detection.
1144
1145 // Initialize the worklist and the DIVariable lookup table.
1146 for (auto *Var : reverse(Input)) {
1147 DbgVar.insert({Var->getVariable(), Var});
1148 WorkList.push_back({Var, 0});
1149 }
1150
1151 // Perform a stable topological sort by doing a DFS.
1152 while (!WorkList.empty()) {
1153 auto Item = WorkList.back();
1154 DbgVariable *Var = Item.getPointer();
1155 bool visitedAllDependencies = Item.getInt();
1156 WorkList.pop_back();
1157
1158 assert(Var);
1159
1160 // Already handled.
1161 if (Visited.count(Var))
1162 continue;
1163
1164 // Add to Result if all dependencies are visited.
1165 if (visitedAllDependencies) {
1166 Visited.insert(Var);
1167 Result.push_back(Var);
1168 continue;
1169 }
1170
1171 // Detect cycles.
1172 auto Res = Visiting.insert(Var);
1173 if (!Res.second) {
1174 assert(false && "dependency cycle in local variables");
1175 return Result;
1176 }
1177
1178 // Push dependencies and this node onto the worklist, so that this node is
1179 // visited again after all of its dependencies are handled.
1180 WorkList.push_back({Var, 1});
1181 for (const auto *Dependency : dependencies(Var)) {
1182 // Don't add dependency if it is in a different lexical scope or a global.
1183 if (const auto *Dep = dyn_cast<const DILocalVariable>(Dependency))
1184 if (DbgVariable *Var = DbgVar.lookup(Dep))
1185 WorkList.push_back({Var, 0});
1186 }
1187 }
1188 return Result;
1189}
1190
1192 const Function &F,
1193 LexicalScope *Scope,
1194 MCSymbol *LineTableSym) {
1195 DIE &ScopeDIE = updateSubprogramScopeDIE(Sub, F, LineTableSym);
1196
1197 if (Scope) {
1198 assert(!Scope->getInlinedAt());
1199 assert(!Scope->isAbstractScope());
1200 // Collect lexical scope children first.
1201 // ObjectPointer might be a local (non-argument) local variable if it's a
1202 // block's synthetic this pointer.
1203 if (DIE *ObjectPointer = createAndAddScopeChildren(Scope, ScopeDIE))
1204 addDIEEntry(ScopeDIE, dwarf::DW_AT_object_pointer, *ObjectPointer);
1205 }
1206
1207 // If this is a variadic function, add an unspecified parameter.
1208 auto *SPTy = Sub->getType();
1209 if (!SPTy)
1210 return ScopeDIE;
1211
1212 DITypeArray FnArgs = SPTy->getTypeArray();
1213
1214 // If we have a single element of null, it is a function that returns void.
1215 // If we have more than one elements and the last one is null, it is a
1216 // variadic function.
1217 if (FnArgs.size() > 1 && !FnArgs[FnArgs.size() - 1] &&
1219 ScopeDIE.addChild(
1220 DIE::get(DIEValueAllocator, dwarf::DW_TAG_unspecified_parameters));
1221
1222 return ScopeDIE;
1223}
1224
1226 DIE &ScopeDIE) {
1227 DIE *ObjectPointer = nullptr;
1228
1229 // Emit function arguments (order is significant).
1230 auto Vars = DU->getScopeVariables().lookup(Scope);
1231 for (auto &DV : Vars.Args)
1232 ScopeDIE.addChild(constructVariableDIE(*DV.second, *Scope, ObjectPointer));
1233
1234 // Emit local variables.
1235 auto Locals = sortLocalVars(Vars.Locals);
1236 for (DbgVariable *DV : Locals)
1237 ScopeDIE.addChild(constructVariableDIE(*DV, *Scope, ObjectPointer));
1238
1239 // Emit labels.
1240 for (DbgLabel *DL : DU->getScopeLabels().lookup(Scope))
1241 ScopeDIE.addChild(constructLabelDIE(*DL, *Scope));
1242
1243 // Track other local entities (skipped in gmlt-like data).
1244 // This creates mapping between CU and a set of local declarations that
1245 // should be emitted for subprograms in this CU.
1246 if (!includeMinimalInlineScopes() && !Scope->getInlinedAt()) {
1247 auto &LocalDecls = DD->getLocalDeclsForScope(Scope->getScopeNode());
1248 DeferredLocalDecls.insert_range(LocalDecls);
1249 }
1250
1251 // Emit inner lexical scopes.
1252 auto skipLexicalScope = [this](LexicalScope *S) -> bool {
1253 if (isa<DISubprogram>(S->getScopeNode()))
1254 return false;
1255 auto Vars = DU->getScopeVariables().lookup(S);
1256 if (!Vars.Args.empty() || !Vars.Locals.empty())
1257 return false;
1258 return includeMinimalInlineScopes() ||
1259 DD->getLocalDeclsForScope(S->getScopeNode()).empty();
1260 };
1261 for (LexicalScope *LS : Scope->getChildren()) {
1262 // If the lexical block doesn't have non-scope children, skip
1263 // its emission and put its children directly to the parent scope.
1264 if (skipLexicalScope(LS))
1265 createAndAddScopeChildren(LS, ScopeDIE);
1266 else
1267 constructScopeDIE(LS, ScopeDIE);
1268 }
1269
1270 return ObjectPointer;
1271}
1272
1274 const DISubprogram *SP) {
1275 if (auto *AbsDef = getAbstractScopeDIEs().lookup(SP))
1276 return *AbsDef;
1277
1278 auto [ContextDIE, ContextCU] = getOrCreateAbstractSubprogramContextDIE(SP);
1279 return createAbstractSubprogramDIE(SP, ContextDIE, ContextCU);
1280}
1281
1282DIE &DwarfCompileUnit::createAbstractSubprogramDIE(
1283 const DISubprogram *SP, DIE *ContextDIE, DwarfCompileUnit *ContextCU) {
1284 // Passing null as the associated node because the abstract definition
1285 // shouldn't be found by lookup.
1286 DIE &AbsDef = ContextCU->createAndAddDIE(dwarf::DW_TAG_subprogram,
1287 *ContextDIE, nullptr);
1288
1289 // Store the DIE before creating children.
1290 ContextCU->getAbstractScopeDIEs()[SP] = &AbsDef;
1291
1292 ContextCU->applySubprogramAttributesToDefinition(SP, AbsDef);
1293 ContextCU->addSInt(AbsDef, dwarf::DW_AT_inline,
1294 DD->getDwarfVersion() <= 4 ? std::optional<dwarf::Form>()
1295 : dwarf::DW_FORM_implicit_const,
1297
1298 return AbsDef;
1299}
1300
1301std::pair<DIE *, DwarfCompileUnit *>
1302DwarfCompileUnit::getOrCreateAbstractSubprogramContextDIE(
1303 const DISubprogram *SP) {
1304 bool Minimal = includeMinimalInlineScopes();
1305 bool IgnoreScope = shouldPlaceInUnitDIE(SP, Minimal);
1306 DIE *ContextDIE = getOrCreateSubprogramContextDIE(SP, IgnoreScope);
1307
1308 if (auto *SPDecl = SP->getDeclaration())
1309 if (!Minimal)
1310 getOrCreateSubprogramDIE(SPDecl, nullptr);
1311
1312 // The scope may be shared with a subprogram that has already been
1313 // constructed in another CU, in which case we need to construct this
1314 // subprogram in the same CU.
1315 auto *ContextCU = IgnoreScope ? this : DD->lookupCU(ContextDIE->getUnitDie());
1316
1317 return std::make_pair(ContextDIE, ContextCU);
1318}
1319
1321 LexicalScope *Scope) {
1322 auto *SP = cast<DISubprogram>(Scope->getScopeNode());
1323
1324 // Populate subprogram DIE only once.
1325 if (!getFinalizedAbstractSubprograms().insert(SP).second)
1326 return;
1327
1328 auto [ContextDIE, ContextCU] = getOrCreateAbstractSubprogramContextDIE(SP);
1329 DIE *AbsDef = getAbstractScopeDIEs().lookup(SP);
1330 if (!AbsDef)
1331 AbsDef = &createAbstractSubprogramDIE(SP, ContextDIE, ContextCU);
1332
1333 if (DIE *ObjectPointer = ContextCU->createAndAddScopeChildren(Scope, *AbsDef))
1334 ContextCU->addDIEEntry(*AbsDef, dwarf::DW_AT_object_pointer,
1335 *ObjectPointer);
1336}
1337
1339 return DD->getDwarfVersion() <= 4 && !DD->tuneForLLDB();
1340}
1341
1344 return Tag;
1345 switch (Tag) {
1346 case dwarf::DW_TAG_call_site:
1347 return dwarf::DW_TAG_GNU_call_site;
1348 case dwarf::DW_TAG_call_site_parameter:
1349 return dwarf::DW_TAG_GNU_call_site_parameter;
1350 default:
1351 llvm_unreachable("DWARF5 tag with no GNU analog");
1352 }
1353}
1354
1358 return Attr;
1359 switch (Attr) {
1360 case dwarf::DW_AT_call_all_calls:
1361 return dwarf::DW_AT_GNU_all_call_sites;
1362 case dwarf::DW_AT_call_target:
1363 return dwarf::DW_AT_GNU_call_site_target;
1364 case dwarf::DW_AT_call_target_clobbered:
1365 return dwarf::DW_AT_GNU_call_site_target_clobbered;
1366 case dwarf::DW_AT_call_origin:
1367 return dwarf::DW_AT_abstract_origin;
1368 case dwarf::DW_AT_call_return_pc:
1369 return dwarf::DW_AT_low_pc;
1370 case dwarf::DW_AT_call_value:
1371 return dwarf::DW_AT_GNU_call_site_value;
1372 case dwarf::DW_AT_call_tail_call:
1373 return dwarf::DW_AT_GNU_tail_call;
1374 default:
1375 llvm_unreachable("DWARF5 attribute with no GNU analog");
1376 }
1377}
1378
1382 return Loc;
1383 switch (Loc) {
1384 case dwarf::DW_OP_entry_value:
1385 return dwarf::DW_OP_GNU_entry_value;
1386 default:
1387 llvm_unreachable("DWARF5 location atom with no GNU analog");
1388 }
1389}
1390
1392 DIE &ScopeDIE, const DISubprogram *CalleeSP, const Function *CalleeF,
1393 bool IsTail, const MCSymbol *PCAddr, const MCSymbol *CallAddr,
1394 MachineLocation CallTarget, int64_t Offset, DIType *AllocSiteTy) {
1395 // Insert a call site entry DIE within ScopeDIE.
1396 DIE &CallSiteDIE = createAndAddDIE(getDwarf5OrGNUTag(dwarf::DW_TAG_call_site),
1397 ScopeDIE, nullptr);
1398
1399 // A valid register in CallTarget indicates an indirect call.
1400 if (CallTarget.getReg()) {
1401 // Add a DW_AT_call_target location expression describing the location of
1402 // the address of the target function. If any register in the expression
1403 // (i.e., the single register we currently handle) is volatile we must use
1404 // DW_AT_call_target_clobbered instead.
1405 const TargetRegisterInfo &TRI = *Asm->MF->getSubtarget().getRegisterInfo();
1407 TRI.isCalleeSavedPhysReg(CallTarget.getReg(), *Asm->MF)
1408 ? dwarf::DW_AT_call_target
1409 : dwarf::DW_AT_call_target_clobbered);
1410
1411 // CallTarget is the location of the address of an indirect call. The
1412 // location may be indirect, modified by Offset.
1413 if (CallTarget.isIndirect())
1414 addMemoryLocation(CallSiteDIE, Attribute, CallTarget, Offset);
1415 else
1416 addAddress(CallSiteDIE, Attribute, CallTarget);
1417 } else if (CalleeSP) {
1418 DIE *CalleeDIE = getOrCreateSubprogramDIE(CalleeSP, CalleeF);
1419 assert(CalleeDIE && "Could not create DIE for call site entry origin");
1420 addLinkageNamesToDeclarations(*DD, *CalleeSP, *CalleeDIE);
1421
1422 addDIEEntry(CallSiteDIE, getDwarf5OrGNUAttr(dwarf::DW_AT_call_origin),
1423 *CalleeDIE);
1424 }
1425
1426 if (IsTail) {
1427 // Attach DW_AT_call_tail_call to tail calls for standards compliance.
1428 addFlag(CallSiteDIE, getDwarf5OrGNUAttr(dwarf::DW_AT_call_tail_call));
1429
1430 // Attach the address of the branch instruction to allow the debugger to
1431 // show where the tail call occurred. This attribute has no GNU analog.
1432 //
1433 // GDB works backwards from non-standard usage of DW_AT_low_pc (in DWARF4
1434 // mode -- equivalently, in DWARF5 mode, DW_AT_call_return_pc) at tail-call
1435 // site entries to figure out the PC of tail-calling branch instructions.
1436 // This means it doesn't need the compiler to emit DW_AT_call_pc, so we
1437 // don't emit it here.
1438 //
1439 // There's no need to tie non-GDB debuggers to this non-standardness, as it
1440 // adds unnecessary complexity to the debugger. For non-GDB debuggers, emit
1441 // the standard DW_AT_call_pc info.
1443 addLabelAddress(CallSiteDIE, dwarf::DW_AT_call_pc, CallAddr);
1444 }
1445
1446 // Attach the return PC to allow the debugger to disambiguate call paths
1447 // from one function to another.
1448 //
1449 // The return PC is only really needed when the call /isn't/ a tail call, but
1450 // GDB expects it in DWARF4 mode, even for tail calls (see the comment above
1451 // the DW_AT_call_pc emission logic for an explanation).
1452 if (!IsTail || useGNUAnalogForDwarf5Feature()) {
1453 assert(PCAddr && "Missing return PC information for a call");
1454 addLabelAddress(CallSiteDIE,
1455 getDwarf5OrGNUAttr(dwarf::DW_AT_call_return_pc), PCAddr);
1456 }
1457
1458 if (AllocSiteTy)
1459 addType(CallSiteDIE, AllocSiteTy, dwarf::DW_AT_LLVM_alloc_type);
1460
1461 return CallSiteDIE;
1462}
1463
1465 DIE &CallSiteDIE, SmallVector<DbgCallSiteParam, 4> &Params) {
1466 for (const auto &Param : Params) {
1467 unsigned Register = Param.getRegister();
1468 auto CallSiteDieParam =
1470 getDwarf5OrGNUTag(dwarf::DW_TAG_call_site_parameter));
1471 insertDIE(CallSiteDieParam);
1472 addAddress(*CallSiteDieParam, dwarf::DW_AT_location,
1474
1476 DIEDwarfExpression DwarfExpr(*Asm, *this, *Loc);
1477 DwarfExpr.setCallSiteParamValueFlag();
1478
1479 DwarfDebug::emitDebugLocValue(*Asm, nullptr, Param.getValue(), DwarfExpr);
1480
1481 addBlock(*CallSiteDieParam, getDwarf5OrGNUAttr(dwarf::DW_AT_call_value),
1482 DwarfExpr.finalize());
1483
1484 CallSiteDIE.addChild(CallSiteDieParam);
1485 }
1486}
1487
1489 const DIImportedEntity *Module) {
1490 DIE *IMDie = DIE::get(DIEValueAllocator, Module->getTag());
1491 insertDIE(Module, IMDie);
1492 DIE *EntityDie;
1493 auto *Entity = Module->getEntity();
1494 if (auto *NS = dyn_cast<DINamespace>(Entity))
1495 EntityDie = getOrCreateNameSpace(NS);
1496 else if (auto *M = dyn_cast<DIModule>(Entity))
1497 EntityDie = getOrCreateModule(M);
1498 else if (auto *SP = dyn_cast<DISubprogram>(Entity)) {
1499 // If there is an abstract subprogram, refer to it. Note that this assumes
1500 // that all the abstract subprograms have been already created (which is
1501 // correct until imported entities get emitted in DwarfDebug::endModule()).
1502 if (auto *AbsSPDie = getAbstractScopeDIEs().lookup(SP))
1503 EntityDie = AbsSPDie;
1504 else
1505 EntityDie = getOrCreateSubprogramDIE(SP, nullptr);
1506 } else if (auto *T = dyn_cast<DIType>(Entity))
1507 EntityDie = getOrCreateTypeDIE(T);
1508 else if (auto *GV = dyn_cast<DIGlobalVariable>(Entity))
1509 EntityDie = getOrCreateGlobalVariableDIE(GV, {});
1510 else if (auto *IE = dyn_cast<DIImportedEntity>(Entity))
1511 EntityDie = getOrCreateImportedEntityDIE(IE);
1512 else
1513 EntityDie = getDIE(Entity);
1514 assert(EntityDie);
1515 addSourceLine(*IMDie, Module->getLine(), /*Column*/ 0, Module->getFile());
1516 addDIEEntry(*IMDie, dwarf::DW_AT_import, *EntityDie);
1517 StringRef Name = Module->getName();
1518 if (!Name.empty()) {
1519 addString(*IMDie, dwarf::DW_AT_name, Name);
1520
1521 // FIXME: if consumers ever start caring about handling
1522 // unnamed import declarations such as `using ::nullptr_t`
1523 // or `using namespace std::ranges`, we could add the
1524 // import declaration into the accelerator table with the
1525 // name being the one of the entity being imported.
1526 DD->addAccelNamespace(*this, CUNode->getNameTableKind(), Name, *IMDie);
1527 }
1528
1529 // This is for imported module with renamed entities (such as variables and
1530 // subprograms).
1531 DINodeArray Elements = Module->getElements();
1532 for (const auto *Element : Elements) {
1533 if (!Element)
1534 continue;
1535 IMDie->addChild(
1537 }
1538
1539 return IMDie;
1540}
1541
1543 const DIImportedEntity *IE) {
1544
1545 // Check for pre-existence.
1546 if (DIE *Die = getDIE(IE))
1547 return Die;
1548
1549 DIE *ContextDIE = getOrCreateContextDIE(IE->getScope());
1550 assert(ContextDIE && "Empty scope for the imported entity!");
1551
1552 DIE *IMDie = constructImportedEntityDIE(IE);
1553 ContextDIE->addChild(IMDie);
1554 return IMDie;
1555}
1556
1558 DIE *D = getDIE(SP);
1559 if (DIE *AbsSPDIE = getAbstractScopeDIEs().lookup(SP)) {
1560 if (D)
1561 // If this subprogram has an abstract definition, reference that
1562 addDIEEntry(*D, dwarf::DW_AT_abstract_origin, *AbsSPDIE);
1563 } else {
1565 if (D)
1566 // And attach the attributes
1568 }
1569}
1570
1572 DbgEntity *AbsEntity = getExistingAbstractEntity(Entity->getEntity());
1573
1574 auto *Die = Entity->getDIE();
1575 /// Label may be used to generate DW_AT_low_pc, so put it outside
1576 /// if/else block.
1577 const DbgLabel *Label = nullptr;
1578 if (AbsEntity && AbsEntity->getDIE()) {
1579 addDIEEntry(*Die, dwarf::DW_AT_abstract_origin, *AbsEntity->getDIE());
1580 Label = dyn_cast<const DbgLabel>(Entity);
1581 } else {
1582 if (const DbgVariable *Var = dyn_cast<const DbgVariable>(Entity))
1584 else if ((Label = dyn_cast<const DbgLabel>(Entity)))
1585 applyLabelAttributes(*Label, *Die);
1586 else
1587 llvm_unreachable("DbgEntity must be DbgVariable or DbgLabel.");
1588 }
1589
1590 if (!Label)
1591 return;
1592
1593 const auto *Sym = Label->getSymbol();
1594 if (!Sym)
1595 return;
1596
1597 addLabelAddress(*Die, dwarf::DW_AT_low_pc, Sym);
1598
1599 // A TAG_label with a name and an AT_low_pc must be placed in debug_names.
1600 if (StringRef Name = Label->getName(); !Name.empty())
1601 getDwarfDebug().addAccelName(*this, CUNode->getNameTableKind(), Name, *Die);
1602}
1603
1605 auto AttachAO = [&](const DILocalScope *LS, DIE *ScopeDIE) {
1606 if (auto *AbsLSDie = getAbstractScopeDIEs().lookup(LS))
1607 addDIEEntry(*ScopeDIE, dwarf::DW_AT_abstract_origin, *AbsLSDie);
1608 };
1609
1610 for (auto [LScope, ScopeDIE] : LexicalBlockDIEs)
1611 AttachAO(LScope, ScopeDIE);
1612 for (auto &[LScope, ScopeDIEs] : InlinedLocalScopeDIEs)
1613 for (auto *ScopeDIE : ScopeDIEs)
1614 AttachAO(LScope, ScopeDIE);
1615}
1616
1618 auto &AbstractEntities = getAbstractEntities();
1619 auto I = AbstractEntities.find(Node);
1620 if (I != AbstractEntities.end())
1621 return I->second.get();
1622 return nullptr;
1623}
1624
1626 LexicalScope *Scope) {
1627 assert(Scope && Scope->isAbstractScope());
1628 auto &Entity = getAbstractEntities()[Node];
1630 Entity = std::make_unique<DbgVariable>(cast<const DILocalVariable>(Node),
1631 nullptr /* IA */);
1632 DU->addScopeVariable(Scope, cast<DbgVariable>(Entity.get()));
1633 } else if (isa<const DILabel>(Node)) {
1634 Entity = std::make_unique<DbgLabel>(
1635 cast<const DILabel>(Node), nullptr /* IA */);
1636 DU->addScopeLabel(Scope, cast<DbgLabel>(Entity.get()));
1637 }
1638}
1639
1640void DwarfCompileUnit::emitHeader(bool UseOffsets) {
1641 // Don't bother labeling the .dwo unit, as its offset isn't used.
1642 if (!Skeleton && !DD->useSectionsAsReferences()) {
1643 LabelBegin = Asm->createTempSymbol("cu_begin");
1644 Asm->OutStreamer->emitLabel(LabelBegin);
1645 }
1646
1647 dwarf::UnitType UT = Skeleton ? dwarf::DW_UT_split_compile
1648 : DD->useSplitDwarf() ? dwarf::DW_UT_skeleton
1649 : dwarf::DW_UT_compile;
1650 DwarfUnit::emitCommonHeader(UseOffsets, UT);
1651 if (DD->getDwarfVersion() >= 5 && UT != dwarf::DW_UT_compile)
1652 Asm->emitInt64(getDWOId());
1653}
1654
1656 if (!DD->shouldEmitDwarfPubSections())
1657 return false;
1658
1659 switch (CUNode->getNameTableKind()) {
1661 return false;
1662 // Opting in to GNU Pubnames/types overrides the default to ensure these are
1663 // generated for things like Gold's gdb_index generation.
1665 return true;
1667 return false;
1669 return DD->tuneForGDB() && !includeMinimalInlineScopes() &&
1670 !CUNode->isDebugDirectivesOnly() &&
1671 DD->getAccelTableKind() != AccelTableKind::Apple &&
1672 DD->getDwarfVersion() < 5;
1673 }
1674 llvm_unreachable("Unhandled DICompileUnit::DebugNameTableKind enum");
1675}
1676
1677/// addGlobalName - Add a new global name to the compile unit.
1679 const DIScope *Context) {
1680 if (!hasDwarfPubSections())
1681 return;
1682 std::string FullName = getParentContextString(Context) + Name.str();
1683 GlobalNames[FullName] = &Die;
1684}
1685
1687 const DIScope *Context) {
1688 if (!hasDwarfPubSections())
1689 return;
1690 std::string FullName = getParentContextString(Context) + Name.str();
1691 // Insert, allowing the entry to remain as-is if it's already present
1692 // This way the CU-level type DIE is preferred over the "can't describe this
1693 // type as a unit offset because it's not really in the CU at all, it's only
1694 // in a type unit"
1695 GlobalNames.insert(std::make_pair(std::move(FullName), &getUnitDie()));
1696}
1697
1698/// Add a new global type to the unit.
1700 const DIScope *Context) {
1701 if (!hasDwarfPubSections())
1702 return;
1703 std::string FullName = getParentContextString(Context) + Ty->getName().str();
1704 GlobalTypes[FullName] = &Die;
1705}
1706
1708 const DIScope *Context) {
1709 if (!hasDwarfPubSections())
1710 return;
1711 std::string FullName = getParentContextString(Context) + Ty->getName().str();
1712 // Insert, allowing the entry to remain as-is if it's already present
1713 // This way the CU-level type DIE is preferred over the "can't describe this
1714 // type as a unit offset because it's not really in the CU at all, it's only
1715 // in a type unit"
1716 GlobalTypes.insert(std::make_pair(std::move(FullName), &getUnitDie()));
1717}
1718
1720 MachineLocation Location) {
1721 auto *Single = std::get_if<Loc::Single>(&DV);
1722 if (Single && Single->getExpr())
1723 addComplexAddress(Single->getExpr(), Die, dwarf::DW_AT_location, Location);
1724 else
1725 addAddress(Die, dwarf::DW_AT_location, Location);
1726}
1727
1728void DwarfCompileUnit::addLocationWithExpr(DIE &Die, dwarf::Attribute Attribute,
1729 const MachineLocation &Location,
1730 ArrayRef<uint64_t> Expr) {
1732 DIEDwarfExpression DwarfExpr(*Asm, *this, *Loc);
1733 if (Location.isIndirect())
1734 DwarfExpr.setMemoryLocationKind();
1735
1736 DIExpressionCursor Cursor(Expr);
1738 if (!DwarfExpr.addMachineRegExpression(TRI, Cursor, Location.getReg()))
1739 return;
1740 DwarfExpr.addExpression(std::move(Cursor));
1741
1742 // Now attach the location information to the DIE.
1743 addBlock(Die, Attribute, DwarfExpr.finalize());
1744
1745 if (DwarfExpr.TagOffset)
1746 addUInt(Die, dwarf::DW_AT_LLVM_tag_offset, dwarf::DW_FORM_data1,
1747 *DwarfExpr.TagOffset);
1748}
1749
1750/// Add an address attribute to a die based on the location provided.
1752 const MachineLocation &Location) {
1753 addLocationWithExpr(Die, Attribute, Location, {});
1754}
1755
1756/// Add a memory location exprloc to \p DIE with attribute \p Attribute
1757/// at \p Location + \p Offset.
1759 const MachineLocation &Location,
1760 int64_t Offset) {
1761 assert(Location.isIndirect() && "Memory loc should be indirect");
1764 addLocationWithExpr(Die, Attribute, Location, Ops);
1765}
1766
1767/// Start with the address based on the location provided, and generate the
1768/// DWARF information necessary to find the actual variable given the extra
1769/// address information encoded in the DbgVariable, starting from the starting
1770/// location. Add the DWARF information to the die.
1773 const MachineLocation &Location) {
1775 DIEDwarfExpression DwarfExpr(*Asm, *this, *Loc);
1776 DwarfExpr.addFragmentOffset(DIExpr);
1777 DwarfExpr.setLocation(Location, DIExpr);
1778
1779 DIExpressionCursor Cursor(DIExpr);
1780
1781 if (DIExpr->isEntryValue())
1782 DwarfExpr.beginEntryValueExpression(Cursor);
1783
1784 const TargetRegisterInfo &TRI = *Asm->MF->getSubtarget().getRegisterInfo();
1785 if (!DwarfExpr.addMachineRegExpression(TRI, Cursor, Location.getReg()))
1786 return;
1787 DwarfExpr.addExpression(std::move(Cursor));
1788
1789 // Now attach the location information to the DIE.
1790 addBlock(Die, Attribute, DwarfExpr.finalize());
1791
1792 if (DwarfExpr.TagOffset)
1793 addUInt(Die, dwarf::DW_AT_LLVM_tag_offset, dwarf::DW_FORM_data1,
1794 *DwarfExpr.TagOffset);
1795}
1796
1797/// Add a Dwarf loclistptr attribute data and value.
1799 unsigned Index) {
1800 dwarf::Form Form = (DD->getDwarfVersion() >= 5)
1801 ? dwarf::DW_FORM_loclistx
1802 : DD->getDwarfSectionOffsetForm();
1803 addAttribute(Die, Attribute, Form, DIELocList(Index));
1804}
1805
1807 DIE &VariableDie) {
1808 StringRef Name = Var.getName();
1809 if (!Name.empty())
1810 addString(VariableDie, dwarf::DW_AT_name, Name);
1811 const auto *DIVar = Var.getVariable();
1812 if (DIVar) {
1813 if (uint32_t AlignInBytes = DIVar->getAlignInBytes())
1814 addUInt(VariableDie, dwarf::DW_AT_alignment, dwarf::DW_FORM_udata,
1815 AlignInBytes);
1816 addAnnotation(VariableDie, DIVar->getAnnotations());
1817 }
1818
1819 addSourceLine(VariableDie, DIVar);
1820 addType(VariableDie, Var.getType());
1821 if (Var.isArtificial())
1822 addFlag(VariableDie, dwarf::DW_AT_artificial);
1823}
1824
1826 DIE &LabelDie) {
1827 StringRef Name = Label.getName();
1828 if (!Name.empty())
1829 addString(LabelDie, dwarf::DW_AT_name, Name);
1830 const auto *DILabel = Label.getLabel();
1831 addSourceLine(LabelDie, DILabel);
1832 if (DILabel->isArtificial())
1833 addFlag(LabelDie, dwarf::DW_AT_artificial);
1835 addUInt(LabelDie, dwarf::DW_AT_LLVM_coro_suspend_idx, std::nullopt,
1837}
1838
1839/// Add a Dwarf expression attribute data and value.
1841 const MCExpr *Expr) {
1842 addAttribute(Die, (dwarf::Attribute)0, Form, DIEExpr(Expr));
1843}
1844
1846 const DISubprogram *SP, DIE &SPDie) {
1847 auto *SPDecl = SP->getDeclaration();
1848 auto *Context = SPDecl ? SPDecl->getScope() : SP->getScope();
1850 addGlobalName(SP->getName(), SPDie, Context);
1851}
1852
1853bool DwarfCompileUnit::isDwoUnit() const {
1854 return DD->useSplitDwarf() && Skeleton;
1855}
1856
1857void DwarfCompileUnit::finishNonUnitTypeDIE(DIE& D, const DICompositeType *CTy) {
1858 constructTypeDIE(D, CTy);
1859}
1860
1863 (DD->useSplitDwarf() && !Skeleton);
1864}
1865
1869
1871 const TargetLoweringObjectFile &TLOF = Asm->getObjFileLowering();
1872 MCSymbol *Label = DD->getAddressPool().getLabel();
1874 DD->getDwarfVersion() >= 5 ? dwarf::DW_AT_addr_base
1875 : dwarf::DW_AT_GNU_addr_base,
1876 Label, TLOF.getDwarfAddrSection()->getBeginSymbol());
1877}
1878
1880 addAttribute(Die, (dwarf::Attribute)0, dwarf::DW_FORM_udata,
1881 new (DIEValueAllocator) DIEBaseTypeRef(this, Idx));
1882}
1883
1885 // Insert the base_type DIEs directly after the CU so that their offsets will
1886 // fit in the fixed size ULEB128 used inside the location expressions.
1887 // Maintain order by iterating backwards and inserting to the front of CU
1888 // child list.
1889 for (auto &Btr : reverse(ExprRefedBaseTypes)) {
1890 DIE &Die = getUnitDie().addChildFront(
1891 DIE::get(DIEValueAllocator, dwarf::DW_TAG_base_type));
1892 SmallString<32> Str;
1893 addString(Die, dwarf::DW_AT_name,
1895 "_" + Twine(Btr.BitSize)).toStringRef(Str));
1896 addUInt(Die, dwarf::DW_AT_encoding, dwarf::DW_FORM_data1, Btr.Encoding);
1897 // Round up to smallest number of bytes that contains this number of bits.
1898 // ExprRefedBaseTypes is populated with types referenced by
1899 // DW_OP_LLVM_convert operations in location expressions. These are often
1900 // byte-sized, but one common counter-example is 1-bit sized conversions
1901 // from `i1` types. TODO: Should these use DW_AT_bit_size? See
1902 // DwarfUnit::constructTypeDIE.
1903 addUInt(Die, dwarf::DW_AT_byte_size, std::nullopt,
1904 divideCeil(Btr.BitSize, 8));
1905 Btr.Die = &Die;
1906 }
1907}
1908
1910 // Assume if there is an abstract tree all the DIEs are already emitted.
1911 bool isAbstract = getAbstractScopeDIEs().count(LB->getSubprogram());
1912 if (isAbstract) {
1913 auto &DIEs = getAbstractScopeDIEs();
1914 if (auto It = DIEs.find(LB); It != DIEs.end())
1915 return It->second;
1916 }
1917 assert(!isAbstract && "Missed lexical block DIE in abstract tree!");
1918
1919 // Check if we have a concrete DIE.
1920 if (auto It = LexicalBlockDIEs.find(LB); It != LexicalBlockDIEs.end())
1921 return It->second;
1922
1923 // If nothing available found, we cannot just create a new lexical block,
1924 // because it isn't known where to put it into the DIE tree.
1925 // So, we may only try to find the most close avaiable parent DIE.
1927}
1928
1930 if (isa_and_nonnull<DILocalScope>(Context)) {
1931 if (auto *LFScope = dyn_cast<DILexicalBlockFile>(Context))
1932 Context = LFScope->getNonLexicalBlockFileScope();
1933 if (auto *LScope = dyn_cast<DILexicalBlock>(Context))
1934 return getLocalContextDIE(LScope);
1935
1936 // Otherwise the context must be a DISubprogram.
1937 auto *SPScope = cast<DISubprogram>(Context);
1938 const auto &DIEs = getAbstractScopeDIEs();
1939 if (auto It = DIEs.find(SPScope); It != DIEs.end())
1940 return It->second;
1941 }
1942 return DwarfUnit::getOrCreateContextDIE(Context);
1943}
1944
1946 const Function *F,
1947 bool Minimal) {
1948 if (!F && SP->isDefinition()) {
1949 F = DD->getLexicalScopes().getFunction(SP);
1950
1951 if (!F) {
1952 // SP may belong to another CU. Determine the CU similarly
1953 // to DwarfDebug::constructAbstractSubprogramScopeDIE.
1954 return &DD->getOrCreateAbstractSubprogramCU(SP, *this)
1955 .getOrCreateAbstractSubprogramDIE(SP);
1956 }
1957 }
1958
1959 return DwarfUnit::getOrCreateSubprogramDIE(SP, F, Minimal);
1960}
1961
1963 const DwarfDebug &DD, const DISubprogram &CalleeSP, DIE &CalleeDIE) {
1965 !CalleeSP.isDefinition() &&
1966 !CalleeDIE.findAttribute(dwarf::DW_AT_linkage_name)) {
1967 addLinkageName(CalleeDIE, CalleeSP.getLinkageName());
1968 }
1969}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock & MBB
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
BitTracker BT
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
dxil translate DXIL Translate Metadata
static SmallVector< DbgVariable *, 8 > sortLocalVars(SmallVectorImpl< DbgVariable * > &Input)
Sort local variables so that variables appearing inside of helper expressions come first.
static const DIType * resolveTypeQualifiers(const DIType *Ty)
static SmallVector< const DIVariable *, 2 > dependencies(DbgVariable *Var)
Return all DIVariables that appear in count: expressions.
static cl::opt< bool > EmitFuncLineTableOffsetsOption("emit-func-debug-line-table-offsets", cl::Hidden, cl::desc("Include line table offset in function's debug info and emit end " "sequence after each function's line data."), cl::init(false))
static bool AddLinkageNamesToDeclCallOriginsForTuning(const DwarfDebug *DD)
static dwarf::Tag GetCompileUnitType(UnitKind Kind, DwarfDebug *DW)
static cl::opt< cl::boolOrDefault > AddLinkageNamesToDeclCallOrigins("add-linkage-names-to-declaration-call-origins", cl::Hidden, cl::desc("Add DW_AT_linkage_name to function declaration DIEs " "referenced by DW_AT_call_origin attributes. Enabled by default " "for -gsce debugger tuning."))
Query value using AddLinkageNamesToDeclCallOriginsForTuning.
This file contains constants used for implementing Dwarf debug support.
static bool lookup(const GsymReader &GR, DataExtractor &Data, uint64_t &Offset, uint64_t BaseAddr, uint64_t Addr, SourceLocations &SrcLocs, llvm::Error &Err)
A Lookup helper functions.
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
#define F(x, y, z)
Definition MD5.cpp:54
#define I(x, y, z)
Definition MD5.cpp:57
Register const TargetRegisterInfo * TRI
Promote Memory to Register
Definition Mem2Reg.cpp:110
#define T
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
This file contains some templates that are useful if you are working with the STL at all.
This file defines the SmallString class.
The Input class is used to parse a yaml document into in-memory structs and vectors.
uint64_t getZExtValue() const
Get zero extended value.
Definition APInt.h:1555
unsigned getBitWidth() const
Return the number of bits in the APInt.
Definition APInt.h:1503
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
size_t size() const
size - Get the array size.
Definition ArrayRef.h:142
This class is intended to be used as a driving class for all asm writers.
Definition AsmPrinter.h:91
MachineFunction * MF
The current machine function.
Definition AsmPrinter.h:109
const DataLayout & getDataLayout() const
Return information about data layout.
MCSymbol * GetExternalSymbolSymbol(const Twine &Sym) const
Return the MCSymbol for the specified ExternalSymbol.
Functions, function parameters, and return types can have attributes to indicate how they should be t...
Definition Attributes.h:105
Debug common block.
DIFile * getFile() const
unsigned getLineNo() const
StringRef getName() const
DIScope * getScope() const
DIGlobalVariable * getDecl() const
static LLVM_ABI std::optional< DebugEmissionKind > getEmissionKind(StringRef Str)
A BaseTypeRef DIE.
Definition DIE.h:363
A BaseTypeRef DIE.
Definition DIE.h:244
DIEBlock - Represents a block of values.
Definition DIE.h:1056
DwarfExpression implementation for singular DW_AT_location.
An expression DIE.
Definition DIE.h:208
An integer value DIE.
Definition DIE.h:169
A label DIE.
Definition DIE.h:226
Represents a pointer to a location list in the debug_loc section.
Definition DIE.h:344
DIELoc - Represents an expression location.
Definition DIE.h:1020
DIE & getUnitDie()
Definition DIE.h:1009
A list of DIE values.
Definition DIE.h:698
value_iterator addValue(BumpPtrAllocator &Alloc, const DIEValue &V)
Definition DIE.h:749
A structured debug information entry.
Definition DIE.h:828
LLVM_ABI DIEValue findAttribute(dwarf::Attribute Attribute) const
Find a value in the DIE with the attribute given.
Definition DIE.cpp:210
DIE & addChild(DIE *Child)
Add a child to the DIE.
Definition DIE.h:944
DIE & addChildFront(DIE *Child)
Definition DIE.h:951
static DIE * get(BumpPtrAllocator &Alloc, dwarf::Tag Tag)
Definition DIE.h:858
LLVM_ABI const DIE * getUnitDie() const
Climb up the parent chain to get the compile unit or type unit DIE that this DIE belongs to.
Definition DIE.cpp:191
Holds a DIExpression and keeps track of how many operands have been consumed so far.
DWARF expression.
element_iterator elements_end() const
LLVM_ABI bool isEntryValue() const
Check if the expression consists of exactly one entry value operand.
iterator_range< expr_op_iterator > expr_ops() const
unsigned getNumElements() const
static LLVM_ABI void appendOffset(SmallVectorImpl< uint64_t > &Ops, int64_t Offset)
Append Ops with operations to apply the Offset.
element_iterator elements_begin() const
ArrayRef< uint64_t > getElements() const
uint64_t getElement(unsigned I) const
LLVM_ABI std::optional< SignedOrUnsignedConstant > isConstant() const
Determine whether this represents a constant value, if so.
DIDerivedType * getStaticDataMemberDeclaration() const
MDTuple * getTemplateParams() const
StringRef getLinkageName() const
StringRef getDisplayName() const
DINodeArray getAnnotations() const
An imported module (C++ using directive or similar).
bool isArtificial() const
std::optional< unsigned > getCoroSuspendIdx() const
DILocalScope * getScope() const
Debug lexical block.
A scope for locals.
LLVM_ABI DISubprogram * getSubprogram() const
Get the subprogram for this scope.
LLVM_ABI DILocalScope * getNonLexicalBlockFileScope() const
Get the first non DILexicalBlockFile scope of this scope.
Tagged DWARF-like metadata node.
LLVM_ABI dwarf::Tag getTag() const
Base class for scope-like contexts.
Subprogram description. Uses SubclassData1.
Base class for types.
uint32_t getAlignInBytes() const
DIScope * getScope() const
DIType * getType() const
StringRef getName() const
LLVM_ABI unsigned getPointerSize(unsigned AS=0) const
The pointer representation size in bytes, rounded up to a whole number of bytes.
This class is defined as the common parent of DbgVariable and DbgLabel such that it could levarage po...
Definition DwarfDebug.h:66
const DINode * getEntity() const
Accessors.
Definition DwarfDebug.h:86
void setDIE(DIE &D)
Definition DwarfDebug.h:92
DIE * getDIE() const
Definition DwarfDebug.h:88
This class is used to track label information.
Definition DwarfDebug.h:290
ArrayRef< DbgValueLocEntry > getLocEntries() const
bool isVariadic() const
This class is used to track local variable information.
Definition DwarfDebug.h:215
bool isArtificial() const
Return true if DbgVariable is artificial.
Definition DwarfDebug.h:263
dwarf::Tag getTag() const
Definition DwarfDebug.h:254
bool isObjectPointer() const
Definition DwarfDebug.h:271
const DILocalVariable * getVariable() const
Definition DwarfDebug.h:247
StringRef getName() const
Definition DwarfDebug.h:251
const DIType * getType() const
Loc::Variant & asVariant()
To workaround P2162R0 https://github.com/cplusplus/papers/issues/873 the base class subobject needs t...
Definition DwarfDebug.h:221
ValueT lookup(const_arg_type_t< KeyT > Val) const
lookup - Return the entry for the specified key, or a default constructed value if no such entry exis...
Definition DenseMap.h:205
std::pair< iterator, bool > insert(const std::pair< KeyT, ValueT > &KV)
Definition DenseMap.h:241
bool useGNUAnalogForDwarf5Feature() const
Whether to use the GNU analog for a DWARF5 tag, attribute, or location atom.
void constructCallSiteParmEntryDIEs(DIE &CallSiteDIE, SmallVector< DbgCallSiteParam, 4 > &Params)
Construct call site parameter DIEs for the CallSiteDIE.
void addLinkageNamesToDeclarations(const DwarfDebug &DD, const DISubprogram &CalleeSP, DIE &CalleeDIE)
void attachLowHighPC(DIE &D, const MCSymbol *Begin, const MCSymbol *End)
void emitHeader(bool UseOffsets) override
Emit the header for this unit, not including the initial length field.
dwarf::Tag getDwarf5OrGNUTag(dwarf::Tag Tag) const
This takes a DWARF 5 tag and returns it or a GNU analog.
void constructAbstractSubprogramScopeDIE(LexicalScope *Scope)
bool includeMinimalInlineScopes() const
DIE * getOrCreateImportedEntityDIE(const DIImportedEntity *IE)
Get or create a DIE for an imported entity.
void addBaseTypeRef(DIEValueList &Die, int64_t Idx)
void addGlobalNameForTypeUnit(StringRef Name, const DIScope *Context)
Add a new global name present in a type unit to this compile unit.
void finishEntityDefinition(const DbgEntity *Entity)
void addMemoryLocation(DIE &Die, dwarf::Attribute Attribute, const MachineLocation &Location, int64_t Offset)
Add a memory location exprloc to DIE with attribute Attribute at Location + Offset.
void addRange(RangeSpan Range)
addRange - Add an address range to the list of ranges for this unit.
void addAddrTableBase()
Add the DW_AT_addr_base attribute to the unit DIE.
std::vector< BaseTypeRef > ExprRefedBaseTypes
DIE * constructInlinedScopeDIE(LexicalScope *Scope, DIE &ParentScopeDIE)
This scope represents an inlined body of a function.
void addScopeRangeList(DIE &ScopeDIE, SmallVector< RangeSpan, 2 > Range)
A helper function to construct a RangeSpanList for a given lexical scope.
uint64_t getDWOId() const
DIE * getOrCreateCommonBlock(const DICommonBlock *CB, ArrayRef< GlobalExpr > GlobalExprs)
void addVariableAddress(const DbgVariable &DV, DIE &Die, MachineLocation Location)
Add DW_AT_location attribute for a DbgVariable based on provided MachineLocation.
DIE & constructCallSiteEntryDIE(DIE &ScopeDIE, const DISubprogram *CalleeSP, const Function *CalleeF, bool IsTail, const MCSymbol *PCAddr, const MCSymbol *CallAddr, MachineLocation CallTarget, int64_t Offset, DIType *AllocSiteTy)
Construct a call site entry DIE describing a call within Scope to a callee described by CalleeSP and ...
DIE & getOrCreateAbstractSubprogramDIE(const DISubprogram *SP)
Create an abstract subprogram DIE, that should later be populated by constructAbstractSubprogramScope...
DIE & constructSubprogramScopeDIE(const DISubprogram *Sub, const Function &F, LexicalScope *Scope, MCSymbol *LineTableSym)
Construct a DIE for this subprogram scope.
void addGlobalName(StringRef Name, const DIE &Die, const DIScope *Context) override
Add a new global name to the compile unit.
DIE & updateSubprogramScopeDIE(const DISubprogram *SP, const Function &F, MCSymbol *LineTableSym)
Find DIE for the given subprogram and attach appropriate DW_AT_low_pc, DW_AT_high_pc and DW_AT_LLVM_s...
void createAbstractEntity(const DINode *Node, LexicalScope *Scope)
void applyStmtList(DIE &D)
Apply the DW_AT_stmt_list from this compile unit to the specified DIE.
DIE * getOrCreateSubprogramDIE(const DISubprogram *SP, const Function *F, bool Minimal=false) override
DIE * getOrCreateContextDIE(const DIScope *Ty) override
Construct a DIE for a given scope.
void applyCommonDbgVariableAttributes(const DbgVariable &Var, DIE &VariableDie)
Add attributes to Var which reflect the common attributes of VariableDie, namely those which are not ...
DIE * constructVariableDIE(DbgVariable &DV, bool Abstract=false)
Construct a DIE for the given DbgVariable.
dwarf::LocationAtom getDwarf5OrGNULocationAtom(dwarf::LocationAtom Loc) const
This takes a DWARF 5 location atom and either returns it or a GNU analog.
DIE * getLocalContextDIE(const DILexicalBlock *LB)
Get DW_TAG_lexical_block for the given DILexicalBlock if available, or the most close parent DIE,...
DIE * getOrCreateGlobalVariableDIE(const DIGlobalVariable *GV, ArrayRef< GlobalExpr > GlobalExprs)
Get or create global variable DIE.
void addLocationAttribute(DIE *ToDIE, const DIGlobalVariable *GV, ArrayRef< GlobalExpr > GlobalExprs)
void applySubprogramAttributesToDefinition(const DISubprogram *SP, DIE &SPDie)
DIE * createAndAddScopeChildren(LexicalScope *Scope, DIE &ScopeDIE)
void addExpr(DIELoc &Die, dwarf::Form Form, const MCExpr *Expr)
Add a Dwarf expression attribute data and value.
DIE * getOrCreateLexicalBlockDIE(LexicalScope *Scope, DIE &ParentDIE)
Get if available or create a new DW_TAG_lexical_block for the given LexicalScope and attach DW_AT_low...
dwarf::Attribute getDwarf5OrGNUAttr(dwarf::Attribute Attr) const
This takes a DWARF 5 attribute and returns it or a GNU analog.
void addAddress(DIE &Die, dwarf::Attribute Attribute, const MachineLocation &Location)
Add an address attribute to a die based on the location provided.
void applyLabelAttributes(const DbgLabel &Label, DIE &LabelDie)
void addLocalLabelAddress(DIE &Die, dwarf::Attribute Attribute, const MCSymbol *Label)
addLocalLabelAddress - Add a dwarf label attribute data and value using DW_FORM_addr only.
void addGlobalTypeImpl(const DIType *Ty, const DIE &Die, const DIScope *Context) override
Add a new global type to the compile unit.
unsigned getOrCreateSourceID(const DIFile *File) override
Look up the source ID for the given file.
void constructScopeDIE(LexicalScope *Scope, DIE &ParentScopeDIE)
DwarfCompileUnit(unsigned UID, const DICompileUnit *Node, AsmPrinter *A, DwarfDebug *DW, DwarfFile *DWU, UnitKind Kind=UnitKind::Full)
DIE * constructLabelDIE(DbgLabel &DL, const LexicalScope &Scope)
Construct a DIE for the given DbgLabel.
void addGlobalTypeUnitType(const DIType *Ty, const DIScope *Context)
Add a new global type present in a type unit to this compile unit.
DbgEntity * getExistingAbstractEntity(const DINode *Node)
void addLabelAddress(DIE &Die, dwarf::Attribute Attribute, const MCSymbol *Label)
addLabelAddress - Add a dwarf label attribute data and value using either DW_FORM_addr or DW_FORM_GNU...
void addLocationList(DIE &Die, dwarf::Attribute Attribute, unsigned Index)
Add a Dwarf loclistptr attribute data and value.
void addComplexAddress(const DIExpression *DIExpr, DIE &Die, dwarf::Attribute Attribute, const MachineLocation &Location)
Start with the address based on the location provided, and generate the DWARF information necessary t...
DIE * constructImportedEntityDIE(const DIImportedEntity *IE)
DwarfCompileUnit & getCU() override
void attachRangesOrLowHighPC(DIE &D, SmallVector< RangeSpan, 2 > Ranges)
void finishSubprogramDefinition(const DISubprogram *SP)
Collects and handles dwarf debug information.
Definition DwarfDebug.h:352
uint16_t getDwarfVersion() const
Returns the Dwarf Version.
DwarfCompileUnit * lookupCU(const DIE *Die)
Find the matching DwarfCompileUnit for the given CU DIE.
Definition DwarfDebug.h:952
static void emitDebugLocValue(const AsmPrinter &AP, const DIBasicType *BT, const DbgValueLoc &Value, DwarfExpression &DwarfExpr)
bool useSplitDwarf() const
Returns whether or not to change the current debug info for the split dwarf proposal support.
Definition DwarfDebug.h:872
void addAccelName(const DwarfUnit &Unit, const DICompileUnit::DebugNameTableKind NameTableKind, StringRef Name, const DIE &Die)
void setLocation(const MachineLocation &Loc, const DIExpression *DIExpr)
Set the location (Loc) and DIExpression (DIExpr) to describe.
void addFragmentOffset(const DIExpression *Expr)
If applicable, emit an empty DW_OP_piece / DW_OP_bit_piece to advance to the fragment described by Ex...
std::optional< uint8_t > TagOffset
void setCallSiteParamValueFlag()
Lock this down to become a call site parameter location.
bool addMachineRegExpression(const TargetRegisterInfo &TRI, DIExpressionCursor &Expr, llvm::Register MachineReg, unsigned FragmentOffsetInBits=0)
Emit a machine register location.
void addExpression(DIExpressionCursor &&Expr)
Emit all remaining operations in the DIExpressionCursor.
void addWasmLocation(unsigned Index, uint64_t Offset)
Emit location information expressed via WebAssembly location + offset The Index is an identifier for ...
void beginEntryValueExpression(DIExpressionCursor &ExprCursor)
Begin emission of an entry value dwarf operation.
virtual DIE * getOrCreateTypeDIE(const MDNode *TyNode)
Find existing DIE or create new DIE for the given type.
DwarfDebug & getDwarfDebug() const
Definition DwarfUnit.h:113
void addAnnotation(DIE &Buffer, DINodeArray Annotations)
Add DW_TAG_LLVM_annotation.
void addBlock(DIE &Die, dwarf::Attribute Attribute, DIELoc *Loc)
Add block data.
void addTemplateParams(DIE &Buffer, DINodeArray TParams)
Add template parameters in buffer.
virtual DIE * getOrCreateContextDIE(const DIScope *Context)
Get context owner's DIE.
void addAttribute(DIEValueList &Die, dwarf::Attribute Attribute, dwarf::Form Form, T &&Value)
Definition DwarfUnit.h:85
void addOpAddress(DIELoc &Die, const MCSymbol *Sym)
Add a dwarf op address data and value using the form given and an op of either DW_FORM_addr or DW_FOR...
void addUInt(DIEValueList &Die, dwarf::Attribute Attribute, std::optional< dwarf::Form > Form, uint64_t Integer)
Add an unsigned integer attribute data and value.
void addString(DIE &Die, dwarf::Attribute Attribute, StringRef Str)
Add a string attribute data and value.
void addConstantValue(DIE &Die, const ConstantInt *CI, const DIType *Ty)
Add constant value entry in variable DIE.
DIE * getOrCreateNameSpace(const DINamespace *NS)
void insertDIE(const DINode *Desc, DIE *D)
Insert DIE into the map.
void addSectionDelta(DIE &Die, dwarf::Attribute Attribute, const MCSymbol *Hi, const MCSymbol *Lo)
addSectionDelta - Add a label delta attribute data and value.
bool shouldPlaceInUnitDIE(const DISubprogram *SP, bool Minimal)
Definition DwarfUnit.h:352
DwarfDebug * DD
Definition DwarfUnit.h:56
const DICompileUnit * CUNode
MDNode for the compile unit.
Definition DwarfUnit.h:41
virtual DIE * getOrCreateSubprogramDIE(const DISubprogram *SP, const Function *FnHint, bool Minimal=false)
DIE * getOrCreateSubprogramContextDIE(const DISubprogram *SP, bool IgnoreScope)
Definition DwarfUnit.h:357
DIE * getDIE(const DINode *D) const
Returns the DIE map slot for the specified debug variable.
MCSymbol * LabelBegin
The start of the unit within its section.
Definition DwarfUnit.h:50
void addSInt(DIEValueList &Die, dwarf::Attribute Attribute, std::optional< dwarf::Form > Form, int64_t Integer)
Add an signed integer attribute data and value.
DwarfUnit(dwarf::Tag, const DICompileUnit *Node, AsmPrinter *A, DwarfDebug *DW, DwarfFile *DWU, unsigned UniqueID=0)
Definition DwarfUnit.cpp:82
void addLabelDelta(DIEValueList &Die, dwarf::Attribute Attribute, const MCSymbol *Hi, const MCSymbol *Lo)
Add a label delta attribute data and value.
void addLinkageName(DIE &Die, StringRef LinkageName)
Add a linkage name, if it isn't empty.
std::string getParentContextString(const DIScope *Context) const
Get string containing language specific context for a global name.
void addSourceLine(DIE &Die, unsigned Line, unsigned Column, const DIFile *File)
Add location information to specified debug information entry.
void emitCommonHeader(bool UseOffsets, dwarf::UnitType UT)
Emit the common part of the header for this unit.
BumpPtrAllocator DIEValueAllocator
Definition DwarfUnit.h:44
DIE * getOrCreateModule(const DIModule *M)
const DICompileUnit * getCUNode() const
Definition DwarfUnit.h:112
DIE & createAndAddDIE(dwarf::Tag Tag, DIE &Parent, const DINode *N=nullptr)
Create a DIE with the given Tag, add the DIE to its parent, and call insertDIE if MD is not null.
DwarfFile * DU
Definition DwarfUnit.h:57
DIE * getOrCreateStaticMemberDIE(const DIDerivedType *DT)
Create new static data member DIE.
void addLabel(DIEValueList &Die, dwarf::Attribute Attribute, dwarf::Form Form, const MCSymbol *Label)
Add a Dwarf label attribute data and value.
void addConstantFPValue(DIE &Die, const ConstantFP *CFP)
Add constant value entry in variable DIE.
void addSectionLabel(DIE &Die, dwarf::Attribute Attribute, const MCSymbol *Label, const MCSymbol *Sec)
Add a Dwarf section label attribute data and value.
void addPoolOpAddress(DIEValueList &Die, const MCSymbol *Label)
void constructTypeDIE(DIE &Buffer, const DICompositeType *CTy)
MCSymbol * EndLabel
Emitted at the end of the CU and used to compute the CU Length field.
Definition DwarfUnit.h:53
void addFlag(DIE &Die, dwarf::Attribute Attribute)
Add a flag that is true to the DIE.
AsmPrinter * Asm
Target of Dwarf emission.
Definition DwarfUnit.h:47
unsigned getUniqueID() const
Gets Unique ID for this unit.
Definition DwarfUnit.h:102
void addType(DIE &Entity, const DIType *Ty, dwarf::Attribute Attribute=dwarf::DW_AT_type)
Add a new type attribute to the specified entity.
void applySubprogramAttributes(const DISubprogram *SP, DIE &SPDie, bool SkipSPAttributes=false)
void addDIEEntry(DIE &Die, dwarf::Attribute Attribute, DIE &Entry)
Add a DIE attribute data and value.
This class is used to track scope information.
Multi-value location description.
Definition DwarfDebug.h:143
unsigned getDebugLocListIndex() const
Definition DwarfDebug.h:154
std::optional< uint8_t > getDebugLocListTagOffset() const
Definition DwarfDebug.h:155
Single value location description.
Definition DwarfDebug.h:132
Base class for the full range of assembler expressions which are needed for parsing.
Definition MCExpr.h:34
MCSection * getDwarfRangesSection() const
MCSection * getDwarfAddrSection() const
MCSection * getDwarfLineSection() const
MCSymbol * getBeginSymbol()
Definition MCSection.h:589
void setType(wasm::WasmSymbolType type)
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
Definition MCSymbol.h:42
bool isDefined() const
isDefined - Check if this symbol is defined (i.e., it has an address).
Definition MCSymbol.h:233
Tuple of metadata.
Definition Metadata.h:1500
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
unsigned getReg() const
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
StringRef getName() const
Get a short "name" for the module.
Definition Module.h:269
Wrapper class representing virtual and physical registers.
Definition Register.h:20
static constexpr bool isPhysicalRegister(unsigned Reg)
Return true if the specified register number is in the physical register namespace.
Definition Register.h:60
Implements a dense probed hash-table based set with some number of buckets stored inline.
Definition DenseSet.h:291
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
Definition SmallString.h:26
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringRef - Represent a constant reference to a string, i.e.
Definition StringRef.h:55
constexpr bool empty() const
empty - Check if the string is empty.
Definition StringRef.h:140
Information about stack frame layout on the target.
virtual DwarfFrameBase getDwarfFrameBase(const MachineFunction &MF) const
Return the frame base information to be encoded in the DWARF subprogram debug info.
virtual StackOffset getFrameIndexReference(const MachineFunction &MF, int FI, Register &FrameReg) const
getFrameIndexReference - This method should return the base register and offset used to reference a f...
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
virtual const TargetRegisterInfo * getRegisterInfo() const =0
Return the target's register information.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
Definition Twine.h:82
StringRef toStringRef(SmallVectorImpl< char > &Out) const
This returns the twine as a single StringRef if it can be represented as such.
Definition Twine.h:461
std::pair< iterator, bool > insert(const ValueT &V)
Definition DenseSet.h:202
size_type count(const_arg_type_t< ValueT > V) const
Return 1 if the specified key is in the set, 0 otherwise.
Definition DenseSet.h:180
A DeclContext is a named program scope that is used for ODR uniquing of types.
bool tuneForSCE() const
Definition DwarfDebug.h:977
LLVM_ABI StringRef AttributeEncodingString(unsigned Encoding)
Definition Dwarf.cpp:263
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
@ Entry
Definition COFF.h:862
initializer< Ty > init(const Ty &Val)
@ DW_INL_inlined
Definition Dwarf.h:777
Attribute
Attributes.
Definition Dwarf.h:125
UnitType
Constants for unit types in DWARF v5.
Definition Dwarf.h:896
@ DW_OP_LLVM_implicit_pointer
Only used in LLVM metadata.
Definition Dwarf.h:148
@ WASM_TYPE_I64
Definition Wasm.h:57
@ WASM_TYPE_I32
Definition Wasm.h:56
@ WASM_SYMBOL_TYPE_GLOBAL
Definition Wasm.h:231
This is an optimization pass for GlobalISel generic memory operations.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:643
auto dyn_cast_if_present(const Y &Val)
dyn_cast_if_present<X> - Functionally identical to dyn_cast, except that a null (or none in the case ...
Definition Casting.h:732
bool isRangeRelaxable(const MCSymbol *Begin, const MCSymbol *End)
Definition MCSymbol.cpp:94
bool isa_and_nonnull(const Y &Val)
Definition Casting.h:676
std::pair< const MachineInstr *, const MachineInstr * > InsnRange
This is used to track range of instructions with identical lexical scope.
auto dyn_cast_or_null(const Y &Val)
Definition Casting.h:753
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1746
auto reverse(ContainerTy &&C)
Definition STLExtras.h:408
@ Apple
.apple_names, .apple_namespaces, .apple_types, .apple_objc.
Definition DwarfDebug.h:347
FunctionAddr VTableAddr Count
Definition InstrProf.h:139
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
Definition Casting.h:547
@ Global
Append to llvm.global_dtors.
constexpr T divideCeil(U Numerator, V Denominator)
Returns the integer ceil(Numerator / Denominator).
Definition MathExtras.h:394
@ Sub
Subtraction of integers.
auto count(R &&Range, const E &Element)
Wrapper function around std::count to count the number of times an element Element occurs in the give...
Definition STLExtras.h:2012
DWARFExpression::Operation Op
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:559
LLVM_ABI DISubprogram * getDISubprogram(const MDNode *Scope)
Find subprogram that is enclosing this scope.
Single location defined by (potentially multiple) EntryValueInfo.
Definition DwarfDebug.h:173
std::set< EntryValueInfo > EntryValues
Definition DwarfDebug.h:174
Single location defined by (potentially multiple) MMI entries.
Definition DwarfDebug.h:160
const std::set< FrameIndexExpr > & getFrameIndexExprs() const
Get the FI entries, sorted by fragment offset.
const MCSymbol * End
Definition DwarfFile.h:41
const MCSymbol * Begin
Definition DwarfFile.h:40
Helper used to pair up a symbol and its DWARF compile unit.
Definition DwarfDebug.h:336
union llvm::TargetFrameLowering::DwarfFrameBase::@004076321055032247336074224075335064105264310375 Location
enum llvm::TargetFrameLowering::DwarfFrameBase::FrameBaseKind Kind