LLVM 23.0.0git
DwarfDebug.cpp
Go to the documentation of this file.
1//===- llvm/CodeGen/DwarfDebug.cpp - Dwarf Debug Framework ----------------===//
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 writing dwarf debug info into asm files.
10//
11//===----------------------------------------------------------------------===//
12
13#include "DwarfDebug.h"
14#include "ByteStreamer.h"
15#include "DIEHash.h"
16#include "DwarfCompileUnit.h"
17#include "DwarfExpression.h"
18#include "DwarfUnit.h"
19#include "llvm/ADT/APInt.h"
20#include "llvm/ADT/Statistic.h"
22#include "llvm/ADT/Twine.h"
24#include "llvm/CodeGen/DIE.h"
36#include "llvm/IR/Constants.h"
38#include "llvm/IR/Function.h"
40#include "llvm/IR/Module.h"
41#include "llvm/MC/MCAsmInfo.h"
42#include "llvm/MC/MCContext.h"
43#include "llvm/MC/MCSection.h"
44#include "llvm/MC/MCStreamer.h"
45#include "llvm/MC/MCSymbol.h"
50#include "llvm/Support/Debug.h"
52#include "llvm/Support/MD5.h"
58#include <cstddef>
59#include <iterator>
60#include <optional>
61#include <string>
62
63using namespace llvm;
64
65#define DEBUG_TYPE "dwarfdebug"
66
67STATISTIC(NumCSParams, "Number of dbg call site params created");
68
70 "use-dwarf-ranges-base-address-specifier", cl::Hidden,
71 cl::desc("Use base address specifiers in debug_ranges"), cl::init(false));
72
73static cl::opt<bool> GenerateARangeSection("generate-arange-section",
75 cl::desc("Generate dwarf aranges"),
76 cl::init(false));
77
78static cl::opt<bool>
79 GenerateDwarfTypeUnits("generate-type-units", cl::Hidden,
80 cl::desc("Generate DWARF4 type units."),
81 cl::init(false));
82
84 "split-dwarf-cross-cu-references", cl::Hidden,
85 cl::desc("Enable cross-cu references in DWO files"), cl::init(false));
86
88
90 "use-unknown-locations", cl::Hidden,
91 cl::desc("Make an absence of debug location information explicit."),
92 cl::values(clEnumVal(Default, "At top of block or after label"),
93 clEnumVal(Enable, "In all cases"), clEnumVal(Disable, "Never")),
95
97 "accel-tables", cl::Hidden, cl::desc("Output dwarf accelerator tables."),
99 "Default for platform"),
100 clEnumValN(AccelTableKind::None, "Disable", "Disabled."),
101 clEnumValN(AccelTableKind::Apple, "Apple", "Apple"),
102 clEnumValN(AccelTableKind::Dwarf, "Dwarf", "DWARF")),
104
106DwarfInlinedStrings("dwarf-inlined-strings", cl::Hidden,
107 cl::desc("Use inlined strings rather than string section."),
108 cl::values(clEnumVal(Default, "Default for platform"),
109 clEnumVal(Enable, "Enabled"),
110 clEnumVal(Disable, "Disabled")),
112
113static cl::opt<bool>
114 NoDwarfRangesSection("no-dwarf-ranges-section", cl::Hidden,
115 cl::desc("Disable emission .debug_ranges section."),
116 cl::init(false));
117
119 "dwarf-sections-as-references", cl::Hidden,
120 cl::desc("Use sections+offset as references rather than labels."),
121 cl::values(clEnumVal(Default, "Default for platform"),
122 clEnumVal(Enable, "Enabled"), clEnumVal(Disable, "Disabled")),
124
125static cl::opt<bool>
126 UseGNUDebugMacro("use-gnu-debug-macro", cl::Hidden,
127 cl::desc("Emit the GNU .debug_macro format with DWARF <5"),
128 cl::init(false));
129
131 "dwarf-op-convert", cl::Hidden,
132 cl::desc("Enable use of the DWARFv5 DW_OP_convert operator"),
133 cl::values(clEnumVal(Default, "Default for platform"),
134 clEnumVal(Enable, "Enabled"), clEnumVal(Disable, "Disabled")),
136
142
144 DwarfLinkageNames("dwarf-linkage-names", cl::Hidden,
145 cl::desc("Which DWARF linkage-name attributes to emit."),
147 "Default for platform"),
148 clEnumValN(AllLinkageNames, "All", "All"),
150 "Abstract subprograms")),
152
154 "minimize-addr-in-v5", cl::Hidden,
155 cl::desc("Always use DW_AT_ranges in DWARFv5 whenever it could allow more "
156 "address pool entry sharing to reduce relocations/object size"),
158 "Default address minimization strategy"),
160 "Use rnglists for contiguous ranges if that allows "
161 "using a pre-existing base address"),
163 "Expressions",
164 "Use exprloc addrx+offset expressions for any "
165 "address with a prior base address"),
167 "Use addrx+offset extension form for any address "
168 "with a prior base address"),
170 "Stuff")),
172
173/// Set to false to ignore Key Instructions metadata.
175 "dwarf-use-key-instructions", cl::Hidden, cl::init(true),
176 cl::desc("Set to false to ignore Key Instructions metadata"));
177
178static constexpr unsigned ULEB128PadSize = 4;
179
180void DebugLocDwarfExpression::emitOp(uint8_t Op, const char *Comment) {
181 getActiveStreamer().emitInt8(
182 Op, Comment ? Twine(Comment) + " " + dwarf::OperationEncodingString(Op)
184}
185
186void DebugLocDwarfExpression::emitSigned(int64_t Value) {
187 getActiveStreamer().emitSLEB128(Value, Twine(Value));
188}
189
190void DebugLocDwarfExpression::emitUnsigned(uint64_t Value) {
191 getActiveStreamer().emitULEB128(Value, Twine(Value));
192}
193
194void DebugLocDwarfExpression::emitData1(uint8_t Value) {
195 getActiveStreamer().emitInt8(Value, Twine(Value));
196}
197
198void DebugLocDwarfExpression::emitBaseTypeRef(uint64_t Idx) {
199 assert(Idx < (1ULL << (ULEB128PadSize * 7)) && "Idx wont fit");
200 getActiveStreamer().emitULEB128(Idx, Twine(Idx), ULEB128PadSize);
201}
202
203bool DebugLocDwarfExpression::isFrameRegister(const TargetRegisterInfo &TRI,
204 llvm::Register MachineReg) {
205 // This information is not available while emitting .debug_loc entries.
206 return false;
207}
208
210 assert(!IsBuffering && "Already buffering?");
211 if (!TmpBuf)
212 TmpBuf = std::make_unique<TempBuffer>(OutBS.GenerateComments);
213 IsBuffering = true;
214}
215
216void DebugLocDwarfExpression::disableTemporaryBuffer() { IsBuffering = false; }
217
219 return TmpBuf ? TmpBuf->Bytes.size() : 0;
220}
221
223 if (!TmpBuf)
224 return;
225 for (auto Byte : enumerate(TmpBuf->Bytes)) {
226 const char *Comment = (Byte.index() < TmpBuf->Comments.size())
227 ? TmpBuf->Comments[Byte.index()].c_str()
228 : "";
229 OutBS.emitInt8(Byte.value(), Comment);
230 }
231 TmpBuf->Bytes.clear();
232 TmpBuf->Comments.clear();
233}
234
236 return getVariable()->getType();
237}
238
239/// Get .debug_loc entry for the instruction range starting at MI.
241 const DIExpression *Expr = MI->getDebugExpression();
242 auto SingleLocExprOpt = DIExpression::convertToNonVariadicExpression(Expr);
243 const bool IsVariadic = !SingleLocExprOpt;
244 // If we have a variadic debug value instruction that is equivalent to a
245 // non-variadic instruction, then convert it to non-variadic form here.
246 if (!IsVariadic && !MI->isNonListDebugValue()) {
247 assert(MI->getNumDebugOperands() == 1 &&
248 "Mismatched DIExpression and debug operands for debug instruction.");
249 Expr = *SingleLocExprOpt;
250 }
251 assert(MI->getNumOperands() >= 3);
252 SmallVector<DbgValueLocEntry, 4> DbgValueLocEntries;
253 for (const MachineOperand &Op : MI->debug_operands()) {
254 if (Op.isReg()) {
255 MachineLocation MLoc(Op.getReg(),
256 MI->isNonListDebugValue() && MI->isDebugOffsetImm());
257 DbgValueLocEntries.push_back(DbgValueLocEntry(MLoc));
258 } else if (Op.isTargetIndex()) {
259 DbgValueLocEntries.push_back(
260 DbgValueLocEntry(TargetIndexLocation(Op.getIndex(), Op.getOffset())));
261 } else if (Op.isImm())
262 DbgValueLocEntries.push_back(DbgValueLocEntry(Op.getImm()));
263 else if (Op.isFPImm())
264 DbgValueLocEntries.push_back(DbgValueLocEntry(Op.getFPImm()));
265 else if (Op.isCImm())
266 DbgValueLocEntries.push_back(DbgValueLocEntry(Op.getCImm()));
267 else
268 llvm_unreachable("Unexpected debug operand in DBG_VALUE* instruction!");
269 }
270 return DbgValueLoc(Expr, DbgValueLocEntries, IsVariadic);
271}
272
274 std::optional<DIExpression::FragmentInfo> Fragment = Expr.getFragmentInfo();
275 return Fragment ? Fragment->OffsetInBits : 0;
276}
277
279 return getFragmentOffsetInBits(*LHS.Expr) <
281}
282
285}
286
288 : ValueLoc(std::make_unique<DbgValueLoc>(ValueLoc)),
289 Expr(ValueLoc.getExpression()) {
290 if (!Expr->getNumElements())
291 Expr = nullptr;
292}
293
296
297const std::set<FrameIndexExpr> &Loc::MMI::getFrameIndexExprs() const {
298 return FrameIndexExprs;
299}
300
301void Loc::MMI::addFrameIndexExpr(const DIExpression *Expr, int FI) {
302 FrameIndexExprs.insert({FI, Expr});
303 assert((FrameIndexExprs.size() == 1 ||
305 [](const FrameIndexExpr &FIE) {
306 return FIE.Expr && FIE.Expr->isFragment();
307 })) &&
308 "conflicting locations for variable");
309}
310
311static AccelTableKind computeAccelTableKind(unsigned DwarfVersion,
312 bool GenerateTypeUnits,
313 DebuggerKind Tuning,
314 const Triple &TT) {
315 // Honor an explicit request.
317 return AccelTables;
318
319 // Generating DWARF5 acceleration table.
320 // Currently Split dwarf and non ELF format is not supported.
321 if (GenerateTypeUnits && (DwarfVersion < 5 || !TT.isOSBinFormatELF()))
323
324 // Accelerator tables get emitted if targetting DWARF v5 or LLDB. DWARF v5
325 // always implies debug_names. For lower standard versions we use apple
326 // accelerator tables on apple platforms and debug_names elsewhere.
327 if (DwarfVersion >= 5)
329 if (Tuning == DebuggerKind::LLDB)
330 return TT.isOSBinFormatMachO() ? AccelTableKind::Apple
333}
334
336 : DebugHandlerBase(A), DebugLocs(A->OutStreamer->isVerboseAsm()),
337 SkeletonHolder(A, "skel_string", DIEValueAllocator),
338 IsDarwin(A->TM.getTargetTriple().isOSDarwin()),
339 InfoHolder(A, "info_string", DIEValueAllocator) {
340 const Triple &TT = Asm->TM.getTargetTriple();
341
342 // Make sure we know our "debugger tuning". The target option takes
343 // precedence; fall back to triple-based defaults.
344 if (Asm->TM.Options.DebuggerTuning != DebuggerKind::Default)
345 DebuggerTuning = Asm->TM.Options.DebuggerTuning;
346 else if (IsDarwin)
347 DebuggerTuning = DebuggerKind::LLDB;
348 else if (TT.isPS())
349 DebuggerTuning = DebuggerKind::SCE;
350 else if (TT.isOSAIX())
351 DebuggerTuning = DebuggerKind::DBX;
352 else
353 DebuggerTuning = DebuggerKind::GDB;
354
356 UseInlineStrings = tuneForDBX();
357 else
358 UseInlineStrings = DwarfInlinedStrings == Enable;
359
360 // Always emit .debug_aranges for SCE tuning.
361 UseARangesSection = GenerateARangeSection || tuneForSCE();
362
363 HasAppleExtensionAttributes = tuneForLLDB();
364
365 // Handle split DWARF.
366 HasSplitDwarf = !Asm->TM.Options.MCOptions.SplitDwarfFile.empty();
367
368 // SCE defaults to linkage names only for abstract subprograms.
370 UseAllLinkageNames = !tuneForSCE();
371 else
372 UseAllLinkageNames = DwarfLinkageNames == AllLinkageNames;
373
374 unsigned DwarfVersionNumber = Asm->TM.Options.MCOptions.DwarfVersion;
375 unsigned DwarfVersion = DwarfVersionNumber ? DwarfVersionNumber
376 : MMI->getModule()->getDwarfVersion();
377 if (!DwarfVersion)
378 DwarfVersion = dwarf::DWARF_VERSION;
379
380 bool Dwarf64 = DwarfVersion >= 3 && // DWARF64 was introduced in DWARFv3.
381 TT.isArch64Bit(); // DWARF64 requires 64-bit relocations.
382
383 // Support DWARF64
384 // 1: For ELF when requested.
385 // 2: For XCOFF64: the AIX assembler will fill in debug section lengths
386 // according to the DWARF64 format for 64-bit assembly, so we must use
387 // DWARF64 in the compiler too for 64-bit mode.
388 Dwarf64 &=
389 ((Asm->TM.Options.MCOptions.Dwarf64 || MMI->getModule()->isDwarf64()) &&
390 TT.isOSBinFormatELF()) ||
391 TT.isOSBinFormatXCOFF();
392
393 if (!Dwarf64 && TT.isArch64Bit() && TT.isOSBinFormatXCOFF())
394 report_fatal_error("XCOFF requires DWARF64 for 64-bit mode!");
395
396 UseRangesSection = !NoDwarfRangesSection;
397
399 UseSectionsAsReferences = DwarfSectionsAsReferences == Enable;
400
401 // Don't generate type units for unsupported object file formats.
402 GenerateTypeUnits = (A->TM.getTargetTriple().isOSBinFormatELF() ||
403 A->TM.getTargetTriple().isOSBinFormatWasm()) &&
405
406 TheAccelTableKind = computeAccelTableKind(
407 DwarfVersion, GenerateTypeUnits, DebuggerTuning, A->TM.getTargetTriple());
408
409 // Work around a GDB bug. GDB doesn't support the standard opcode;
410 // SCE doesn't support GNU's; LLDB prefers the standard opcode, which
411 // is defined as of DWARF 3.
412 // See GDB bug 11616 - DW_OP_form_tls_address is unimplemented
413 // https://sourceware.org/bugzilla/show_bug.cgi?id=11616
414 UseGNUTLSOpcode = tuneForGDB() || DwarfVersion < 3;
415
416 UseDWARF2Bitfields = DwarfVersion < 4;
417
418 // The DWARF v5 string offsets table has - possibly shared - contributions
419 // from each compile and type unit each preceded by a header. The string
420 // offsets table used by the pre-DWARF v5 split-DWARF implementation uses
421 // a monolithic string offsets table without any header.
422 UseSegmentedStringOffsetsTable = DwarfVersion >= 5;
423
424 // Emit call-site-param debug info for GDB and LLDB, if the target supports
425 // the debug entry values feature. It can also be enabled explicitly.
426 EmitDebugEntryValues = Asm->TM.Options.ShouldEmitDebugEntryValues();
427
428 // It is unclear if the GCC .debug_macro extension is well-specified
429 // for split DWARF. For now, do not allow LLVM to emit it.
430 UseDebugMacroSection =
431 DwarfVersion >= 5 || (UseGNUDebugMacro && !useSplitDwarf());
432 if (DwarfOpConvert == Default)
433 EnableOpConvert = !((tuneForGDB() && useSplitDwarf()) || (tuneForLLDB() && !TT.isOSBinFormatMachO()));
434 else
435 EnableOpConvert = (DwarfOpConvert == Enable);
436
437 // Split DWARF would benefit object size significantly by trading reductions
438 // in address pool usage for slightly increased range list encodings.
439 if (DwarfVersion >= 5)
440 MinimizeAddr = MinimizeAddrInV5Option;
441
442 Asm->OutStreamer->getContext().setDwarfVersion(DwarfVersion);
443 Asm->OutStreamer->getContext().setDwarfFormat(Dwarf64 ? dwarf::DWARF64
445}
446
447// Define out of line so we don't have to include DwarfUnit.h in DwarfDebug.h.
448DwarfDebug::~DwarfDebug() = default;
449
450static bool isObjCClass(StringRef Name) {
451 return Name.starts_with("+") || Name.starts_with("-");
452}
453
454static bool hasObjCCategory(StringRef Name) {
455 if (!isObjCClass(Name))
456 return false;
457
458 return Name.contains(") ");
459}
460
462 StringRef &Category) {
463 if (!hasObjCCategory(In)) {
464 Class = In.slice(In.find('[') + 1, In.find(' '));
465 Category = "";
466 return;
467 }
468
469 Class = In.slice(In.find('[') + 1, In.find('('));
470 Category = In.slice(In.find('[') + 1, In.find(' '));
471}
472
474 return In.slice(In.find(' ') + 1, In.find(']'));
475}
476
477// Add the various names to the Dwarf accelerator table names.
479 const DwarfUnit &Unit,
480 const DICompileUnit::DebugNameTableKind NameTableKind,
481 const DISubprogram *SP, DIE &Die) {
485 return;
486
487 if (!SP->isDefinition())
488 return;
489
490 if (SP->getName() != "")
491 addAccelName(Unit, NameTableKind, SP->getName(), Die);
492
493 // We drop the mangling escape prefix when emitting the DW_AT_linkage_name. So
494 // ensure we don't include it when inserting into the accelerator tables.
496 GlobalValue::dropLLVMManglingEscape(SP->getLinkageName());
497
498 // If the linkage name is different than the name, go ahead and output that as
499 // well into the name table. Only do that if we are going to actually emit
500 // that name.
501 if (LinkageName != "" && SP->getName() != LinkageName &&
502 (useAllLinkageNames() || InfoHolder.getAbstractScopeDIEs().lookup(SP)))
503 addAccelName(Unit, NameTableKind, LinkageName, Die);
504
505 // If this is an Objective-C selector name add it to the ObjC accelerator
506 // too.
507 if (isObjCClass(SP->getName())) {
508 StringRef Class, Category;
509 getObjCClassCategory(SP->getName(), Class, Category);
510 addAccelObjC(Unit, NameTableKind, Class, Die);
511 if (Category != "")
512 addAccelObjC(Unit, NameTableKind, Category, Die);
513 // Also add the base method name to the name table.
514 addAccelName(Unit, NameTableKind, getObjCMethodName(SP->getName()), Die);
515 }
516}
517
518/// Check whether we should create a DIE for the given Scope, return true
519/// if we don't create a DIE (the corresponding DIE is null).
521 if (Scope->isAbstractScope())
522 return false;
523
524 // We don't create a DIE if there is no Range.
525 const SmallVectorImpl<InsnRange> &Ranges = Scope->getRanges();
526 if (Ranges.empty())
527 return true;
528
529 if (Ranges.size() > 1)
530 return false;
531
532 // We don't create a DIE if we have a single Range and the end label
533 // is null.
534 return !getLabelAfterInsn(Ranges.front().second);
535}
536
537template <typename Func> static void forBothCUs(DwarfCompileUnit &CU, Func F) {
538 F(CU);
539 if (auto *SkelCU = CU.getSkeleton())
540 if (CU.getCUNode()->getSplitDebugInlining())
541 F(*SkelCU);
542}
543
547
550 DwarfCompileUnit &SrcCU) {
551 auto &CU = getOrCreateDwarfCompileUnit(SP->getUnit());
552 if (CU.getSkeleton())
553 return shareAcrossDWOCUs() ? CU : SrcCU;
554
555 return CU;
556}
557
558void DwarfDebug::constructAbstractSubprogramScopeDIE(DwarfCompileUnit &SrcCU,
559 LexicalScope *Scope) {
560 assert(Scope && Scope->getScopeNode());
561 assert(Scope->isAbstractScope());
562 assert(!Scope->getInlinedAt());
563
564 auto *SP = cast<DISubprogram>(Scope->getScopeNode());
565
566 // Find the subprogram's DwarfCompileUnit in the SPMap in case the subprogram
567 // was inlined from another compile unit.
568 auto &CU = getOrCreateDwarfCompileUnit(SP->getUnit());
569 auto &TargetCU = getOrCreateAbstractSubprogramCU(SP, SrcCU);
570 TargetCU.constructAbstractSubprogramScopeDIE(Scope);
571 if (auto *SkelCU = CU.getSkeleton())
572 if (CU.getCUNode()->getSplitDebugInlining())
573 SkelCU->constructAbstractSubprogramScopeDIE(Scope);
574}
575
576/// Represents a parameter whose call site value can be described by applying a
577/// debug expression to a register in the forwarded register worklist.
579 /// The described parameter register.
581
582 /// Debug expression that has been built up when walking through the
583 /// instruction chain that produces the parameter's value.
585};
586
587/// Register worklist for finding call site values.
589/// Container for the set of register units known to be clobbered on the path
590/// to a call site.
592
593/// Append the expression \p Addition to \p Original and return the result.
594static const DIExpression *combineDIExpressions(const DIExpression *Original,
595 const DIExpression *Addition) {
596 std::vector<uint64_t> Elts = Addition->getElements().vec();
597 // Avoid multiple DW_OP_stack_values.
598 if (Original->isImplicit() && Addition->isImplicit())
599 llvm::erase(Elts, dwarf::DW_OP_stack_value);
600 const DIExpression *CombinedExpr =
601 (Elts.size() > 0) ? DIExpression::append(Original, Elts) : Original;
602 return CombinedExpr;
603}
604
605/// Emit call site parameter entries that are described by the given value and
606/// debug expression.
607template <typename ValT>
608static void finishCallSiteParams(ValT Val, const DIExpression *Expr,
609 ArrayRef<FwdRegParamInfo> DescribedParams,
610 ParamSet &Params) {
611 for (auto Param : DescribedParams) {
612 bool ShouldCombineExpressions = Expr && Param.Expr->getNumElements() > 0;
613
614 // If a parameter's call site value is produced by a chain of
615 // instructions we may have already created an expression for the
616 // parameter when walking through the instructions. Append that to the
617 // base expression.
618 const DIExpression *CombinedExpr =
619 ShouldCombineExpressions ? combineDIExpressions(Expr, Param.Expr)
620 : Expr;
621 assert((!CombinedExpr || CombinedExpr->isValid()) &&
622 "Combined debug expression is invalid");
623
624 DbgValueLoc DbgLocVal(CombinedExpr, DbgValueLocEntry(Val));
625 DbgCallSiteParam CSParm(Param.ParamReg, DbgLocVal);
626 Params.push_back(CSParm);
627 ++NumCSParams;
628 }
629}
630
631/// Add \p Reg to the worklist, if it's not already present, and mark that the
632/// given parameter registers' values can (potentially) be described using
633/// that register and an debug expression.
634static void addToFwdRegWorklist(FwdRegWorklist &Worklist, unsigned Reg,
635 const DIExpression *Expr,
636 ArrayRef<FwdRegParamInfo> ParamsToAdd) {
637 auto &ParamsForFwdReg = Worklist[Reg];
638 for (auto Param : ParamsToAdd) {
639 assert(none_of(ParamsForFwdReg,
640 [Param](const FwdRegParamInfo &D) {
641 return D.ParamReg == Param.ParamReg;
642 }) &&
643 "Same parameter described twice by forwarding reg");
644
645 // If a parameter's call site value is produced by a chain of
646 // instructions we may have already created an expression for the
647 // parameter when walking through the instructions. Append that to the
648 // new expression.
649 const DIExpression *CombinedExpr = combineDIExpressions(Expr, Param.Expr);
650 ParamsForFwdReg.push_back({Param.ParamReg, CombinedExpr});
651 }
652}
653
654/// Interpret values loaded into registers by \p CurMI.
655static void interpretValues(const MachineInstr *CurMI,
656 FwdRegWorklist &ForwardedRegWorklist,
657 ParamSet &Params,
658 ClobberedRegUnitSet &ClobberedRegUnits) {
659
660 const MachineFunction *MF = CurMI->getMF();
661 const DIExpression *EmptyExpr =
663 const auto &TRI = *MF->getSubtarget().getRegisterInfo();
664 const auto &TII = *MF->getSubtarget().getInstrInfo();
665 const auto &TLI = *MF->getSubtarget().getTargetLowering();
666
667 // It's possible that we find a copy from a non-volatile register to the param
668 // register, which is clobbered in the meantime. Test for clobbered reg unit
669 // overlaps before completing.
670 auto IsRegClobberedInMeantime = [&](Register Reg) -> bool {
671 for (auto &RegUnit : ClobberedRegUnits)
672 if (TRI.hasRegUnit(Reg, RegUnit))
673 return true;
674 return false;
675 };
676
677 auto DescribeFwdRegsByCalleeSavedCopy = [&](const DestSourcePair &CopyInst) {
678 Register CopyDestReg = CopyInst.Destination->getReg();
679 Register CopySrcReg = CopyInst.Source->getReg();
680 if (IsRegClobberedInMeantime(CopyDestReg))
681 return;
682 // FIXME: This may be incorrect in cases where the caller and callee use
683 // different calling conventions.
684 if (!TRI.isCalleeSavedPhysReg(CopyDestReg, *MF))
685 return;
686 // Describe any forward registers matching the source register. If the
687 // forward register is a sub-register of the source, we describe it using
688 // the corresponding sub-register in the destination, if such a
689 // sub-register exists. The end iterator in the MapVector is invalidated at
690 // erase(), so it needs to be evaluated at each iteration.
691 for (auto FwdRegIt = ForwardedRegWorklist.begin();
692 FwdRegIt != ForwardedRegWorklist.end();) {
694 if (FwdRegIt->first == CopySrcReg)
695 CalleeSavedReg = CopyDestReg;
696 else if (unsigned SubRegIdx =
697 TRI.getSubRegIndex(CopySrcReg, FwdRegIt->first))
698 if (Register CopyDestSubReg = TRI.getSubReg(CopyDestReg, SubRegIdx))
699 CalleeSavedReg = CopyDestSubReg;
700
702 ++FwdRegIt;
703 continue;
704 }
705
706 MachineLocation MLoc(CalleeSavedReg, /*Indirect=*/false);
707 finishCallSiteParams(MLoc, EmptyExpr, FwdRegIt->second, Params);
708 FwdRegIt = ForwardedRegWorklist.erase(FwdRegIt);
709 }
710 };
711
712 // Detect if this is a copy instruction. If this saves any of the forward
713 // registers in callee-saved registers, we can finalize those parameters
714 // directly.
715 // TODO: Can we do something similar for stack saves?
716 if (auto CopyInst = TII.isCopyInstr(*CurMI))
717 DescribeFwdRegsByCalleeSavedCopy(*CopyInst);
718
719 // If an instruction defines more than one item in the worklist, we may run
720 // into situations where a worklist register's value is (potentially)
721 // described by the previous value of another register that is also defined
722 // by that instruction.
723 //
724 // This can for example occur in cases like this:
725 //
726 // $r1 = mov 123
727 // $r0, $r1 = mvrr $r1, 456
728 // call @foo, $r0, $r1
729 //
730 // When describing $r1's value for the mvrr instruction, we need to make sure
731 // that we don't finalize an entry value for $r0, as that is dependent on the
732 // previous value of $r1 (123 rather than 456).
733 //
734 // In order to not have to distinguish between those cases when finalizing
735 // entry values, we simply postpone adding new parameter registers to the
736 // worklist, by first keeping them in this temporary container until the
737 // instruction has been handled.
738 FwdRegWorklist TmpWorklistItems;
739
740 // If the MI is an instruction defining one or more parameters' forwarding
741 // registers, add those defines.
742 ClobberedRegUnitSet NewClobberedRegUnits;
743 auto getForwardingRegsDefinedByMI = [&](const MachineInstr &MI,
745 if (MI.isDebugInstr())
746 return;
747
748 for (const MachineOperand &MO : MI.all_defs()) {
749 if (MO.getReg().isPhysical()) {
750 for (auto &FwdReg : ForwardedRegWorklist)
751 if (TRI.regsOverlap(FwdReg.first, MO.getReg()))
752 Defs.insert(FwdReg.first);
753 NewClobberedRegUnits.insert_range(TRI.regunits(MO.getReg()));
754 }
755 }
756 };
757
758 // Set of worklist registers that are defined by this instruction.
760
761 getForwardingRegsDefinedByMI(*CurMI, FwdRegDefs);
762 if (FwdRegDefs.empty()) {
763 // Any definitions by this instruction will clobber earlier reg movements.
764 ClobberedRegUnits.insert_range(NewClobberedRegUnits);
765 return;
766 }
767
768 for (auto ParamFwdReg : FwdRegDefs) {
769 if (auto ParamValue = TII.describeLoadedValue(*CurMI, ParamFwdReg)) {
770 if (ParamValue->first.isImm()) {
771 int64_t Val = ParamValue->first.getImm();
772 finishCallSiteParams(Val, ParamValue->second,
773 ForwardedRegWorklist[ParamFwdReg], Params);
774 } else if (ParamValue->first.isReg()) {
775 Register RegLoc = ParamValue->first.getReg();
776 Register SP = TLI.getStackPointerRegisterToSaveRestore();
777 Register FP = TRI.getFrameRegister(*MF);
778 bool IsSPorFP = (RegLoc == SP) || (RegLoc == FP);
779 // FIXME: This may be incorrect in cases where the caller and callee use
780 // different calling conventions.
781 if (!IsRegClobberedInMeantime(RegLoc) &&
782 (TRI.isCalleeSavedPhysReg(RegLoc, *MF) || IsSPorFP)) {
783 MachineLocation MLoc(RegLoc, /*Indirect=*/IsSPorFP);
784 finishCallSiteParams(MLoc, ParamValue->second,
785 ForwardedRegWorklist[ParamFwdReg], Params);
786 } else {
787 // ParamFwdReg was described by the non-callee saved register
788 // RegLoc. Mark that the call site values for the parameters are
789 // dependent on that register instead of ParamFwdReg. Since RegLoc
790 // may be a register that will be handled in this iteration, we
791 // postpone adding the items to the worklist, and instead keep them
792 // in a temporary container.
793 addToFwdRegWorklist(TmpWorklistItems, RegLoc, ParamValue->second,
794 ForwardedRegWorklist[ParamFwdReg]);
795 }
796 }
797 }
798 }
799
800 // Remove all registers that this instruction defines from the worklist.
801 for (auto ParamFwdReg : FwdRegDefs)
802 ForwardedRegWorklist.erase(ParamFwdReg);
803
804 // Any definitions by this instruction will clobber earlier reg movements.
805 ClobberedRegUnits.insert_range(NewClobberedRegUnits);
806
807 // Now that we are done handling this instruction, add items from the
808 // temporary worklist to the real one.
809 for (auto &New : TmpWorklistItems)
810 addToFwdRegWorklist(ForwardedRegWorklist, New.first, EmptyExpr, New.second);
811 TmpWorklistItems.clear();
812}
813
814static bool interpretNextInstr(const MachineInstr *CurMI,
815 FwdRegWorklist &ForwardedRegWorklist,
816 ParamSet &Params,
817 ClobberedRegUnitSet &ClobberedRegUnits) {
818 // Skip bundle headers.
819 if (CurMI->isBundle())
820 return true;
821
822 // If the next instruction is a call we can not interpret parameter's
823 // forwarding registers or we finished the interpretation of all
824 // parameters.
825 if (CurMI->isCall())
826 return false;
827
828 if (ForwardedRegWorklist.empty())
829 return false;
830
831 // Avoid NOP description.
832 if (CurMI->getNumOperands() == 0)
833 return true;
834
835 interpretValues(CurMI, ForwardedRegWorklist, Params, ClobberedRegUnits);
836
837 return true;
838}
839
840/// Try to interpret values loaded into registers that forward parameters
841/// for \p CallMI. Store parameters with interpreted value into \p Params.
842static void collectCallSiteParameters(const MachineInstr *CallMI,
843 ParamSet &Params) {
844 const MachineFunction *MF = CallMI->getMF();
845 const auto &CalleesMap = MF->getCallSitesInfo();
846 auto CSInfo = CalleesMap.find(CallMI);
847
848 // There is no information for the call instruction.
849 if (CSInfo == CalleesMap.end())
850 return;
851
852 const MachineBasicBlock *MBB = CallMI->getParent();
853
854 // Skip the call instruction.
855 auto I = std::next(CallMI->getReverseIterator());
856
857 FwdRegWorklist ForwardedRegWorklist;
858
859 const DIExpression *EmptyExpr =
861
862 // Add all the forwarding registers into the ForwardedRegWorklist.
863 for (const auto &ArgReg : CSInfo->second.ArgRegPairs) {
864 bool InsertedReg =
865 ForwardedRegWorklist.insert({ArgReg.Reg, {{ArgReg.Reg, EmptyExpr}}})
866 .second;
867 assert(InsertedReg && "Single register used to forward two arguments?");
868 (void)InsertedReg;
869 }
870
871 // Do not emit CSInfo for undef forwarding registers.
872 for (const auto &MO : CallMI->uses())
873 if (MO.isReg() && MO.isUndef())
874 ForwardedRegWorklist.erase(MO.getReg());
875
876 // We erase, from the ForwardedRegWorklist, those forwarding registers for
877 // which we successfully describe a loaded value (by using
878 // the describeLoadedValue()). For those remaining arguments in the working
879 // list, for which we do not describe a loaded value by
880 // the describeLoadedValue(), we try to generate an entry value expression
881 // for their call site value description, if the call is within the entry MBB.
882 // TODO: Handle situations when call site parameter value can be described
883 // as the entry value within basic blocks other than the first one.
884 bool ShouldTryEmitEntryVals = MBB->getIterator() == MF->begin();
885
886 // Search for a loading value in forwarding registers inside call delay slot.
887 ClobberedRegUnitSet ClobberedRegUnits;
888 if (CallMI->hasDelaySlot()) {
889 auto Suc = std::next(CallMI->getIterator());
890 // Only one-instruction delay slot is supported.
891 auto BundleEnd = llvm::getBundleEnd(CallMI->getIterator());
892 (void)BundleEnd;
893 assert(std::next(Suc) == BundleEnd &&
894 "More than one instruction in call delay slot");
895 // Try to interpret value loaded by instruction.
896 if (!interpretNextInstr(&*Suc, ForwardedRegWorklist, Params, ClobberedRegUnits))
897 return;
898 }
899
900 // Search for a loading value in forwarding registers.
901 for (; I != MBB->rend(); ++I) {
902 // Try to interpret values loaded by instruction.
903 if (!interpretNextInstr(&*I, ForwardedRegWorklist, Params, ClobberedRegUnits))
904 return;
905 }
906
907 // Emit the call site parameter's value as an entry value.
908 if (ShouldTryEmitEntryVals) {
909 // Create an expression where the register's entry value is used.
910 DIExpression *EntryExpr = DIExpression::get(
911 MF->getFunction().getContext(), {dwarf::DW_OP_LLVM_entry_value, 1});
912 for (auto &RegEntry : ForwardedRegWorklist) {
913 MachineLocation MLoc(RegEntry.first);
914 finishCallSiteParams(MLoc, EntryExpr, RegEntry.second, Params);
915 }
916 }
917}
918
919void DwarfDebug::constructCallSiteEntryDIEs(const DISubprogram &SP,
920 DwarfCompileUnit &CU, DIE &ScopeDIE,
921 const MachineFunction &MF) {
922 // Add a call site-related attribute (DWARF5, Sec. 3.3.1.3). Do this only if
923 // the subprogram is required to have one.
924 if (!SP.areAllCallsDescribed() || !SP.isDefinition())
925 return;
926
927 // Use DW_AT_call_all_calls to express that call site entries are present
928 // for both tail and non-tail calls. Don't use DW_AT_call_all_source_calls
929 // because one of its requirements is not met: call site entries for
930 // optimized-out calls are elided.
931 CU.addFlag(ScopeDIE, CU.getDwarf5OrGNUAttr(dwarf::DW_AT_call_all_calls));
932
933 const TargetInstrInfo *TII = MF.getSubtarget().getInstrInfo();
934 assert(TII && "TargetInstrInfo not found: cannot label tail calls");
935
936 // Delay slot support check.
937 auto delaySlotSupported = [&](const MachineInstr &MI) {
938 if (!MI.isBundledWithSucc())
939 return false;
940 auto Suc = std::next(MI.getIterator());
941 auto CallInstrBundle = getBundleStart(MI.getIterator());
942 (void)CallInstrBundle;
943 auto DelaySlotBundle = getBundleStart(Suc);
944 (void)DelaySlotBundle;
945 // Ensure that label after call is following delay slot instruction.
946 // Ex. CALL_INSTRUCTION {
947 // DELAY_SLOT_INSTRUCTION }
948 // LABEL_AFTER_CALL
949 assert(getLabelAfterInsn(&*CallInstrBundle) ==
950 getLabelAfterInsn(&*DelaySlotBundle) &&
951 "Call and its successor instruction don't have same label after.");
952 return true;
953 };
954
955 // Create call_target connections for indirect calls.
956 auto addCallSiteTargetForIndirectCalls = [&](const MachineInstr *MI,
957 DIE &CallSiteDIE) {
958 const MachineFunction *MF = MI->getMF();
959 const auto &CalleesMap = MF->getCallSitesInfo();
960 auto CSInfo = CalleesMap.find(MI);
961 // Get the information for the call instruction.
962 if (CSInfo == CalleesMap.end() || !CSInfo->second.CallTarget)
963 return;
964
965 MDNode *CallTarget = CSInfo->second.CallTarget;
966 // Add DW_AT_LLVM_virtual_call_origin with the 'call_target' metadata.
967 assert(!CallSiteDIE.findAttribute(dwarf::DW_AT_LLVM_virtual_call_origin) &&
968 "DW_AT_LLVM_virtual_call_origin already exists");
969 const DISubprogram *CalleeSP = dyn_cast<DISubprogram>(CallTarget);
970 DIE *CalleeDIE = CU.getOrCreateSubprogramDIE(CalleeSP, nullptr);
971 assert(CalleeDIE && "Could not create DIE for call site entry origin");
972 CU.addDIEEntry(CallSiteDIE,
973 CU.getDwarf5OrGNUAttr(dwarf::DW_AT_LLVM_virtual_call_origin),
974 *CalleeDIE);
975 // Add DW_AT_linkage_name to the method declaration if needed.
976 CU.addLinkageNamesToDeclarations(*this, *CalleeSP, *CalleeDIE);
977 };
978
979 // Emit call site entries for each call or tail call in the function.
980 for (const MachineBasicBlock &MBB : MF) {
981 for (const MachineInstr &MI : MBB.instrs()) {
982 // Bundles with call in them will pass the isCall() test below but do not
983 // have callee operand information so skip them here. Iterator will
984 // eventually reach the call MI.
985 if (MI.isBundle())
986 continue;
987
988 // Skip instructions which aren't calls. Both calls and tail-calling jump
989 // instructions (e.g TAILJMPd64) are classified correctly here.
990 if (!MI.isCandidateForAdditionalCallInfo())
991 continue;
992
993 // Skip instructions marked as frame setup, as they are not interesting to
994 // the user.
995 if (MI.getFlag(MachineInstr::FrameSetup))
996 continue;
997
998 // Check if delay slot support is enabled.
999 if (MI.hasDelaySlot() && !delaySlotSupported(*&MI))
1000 return;
1001
1002 DIType *AllocSiteTy = dyn_cast_or_null<DIType>(MI.getHeapAllocMarker());
1003
1004 // If this is a direct call, find the callee's subprogram.
1005 // In the case of an indirect call find the register or memory location
1006 // that holds the callee address.
1007 const MachineOperand &CalleeOp = TII->getCalleeOperand(MI);
1008 bool PhysRegCalleeOperand =
1009 CalleeOp.isReg() && CalleeOp.getReg().isPhysical();
1010 MachineLocation CallTarget{0};
1011 int64_t Offset = 0;
1012 const DISubprogram *CalleeSP = nullptr;
1013 const Function *CalleeDecl = nullptr;
1014 if (PhysRegCalleeOperand) {
1015 bool Scalable = false;
1016 const MachineOperand *BaseOp = nullptr;
1017 const TargetRegisterInfo &TRI =
1018 *Asm->MF->getSubtarget().getRegisterInfo();
1019 if (TII->getMemOperandWithOffset(MI, BaseOp, Offset, Scalable, &TRI)) {
1020 if (BaseOp && BaseOp->isReg() && !Scalable)
1021 CallTarget = MachineLocation(BaseOp->getReg(), /*Indirect*/ true);
1022 }
1023
1024 if (!CallTarget.isIndirect())
1025 CallTarget = MachineLocation(CalleeOp.getReg()); // Might be zero.
1026 } else if (CalleeOp.isGlobal()) {
1027 CalleeDecl = dyn_cast<Function>(CalleeOp.getGlobal());
1028 if (CalleeDecl)
1029 CalleeSP = CalleeDecl->getSubprogram(); // might be nullptr
1030 }
1031
1032 // Omit DIE if we can't tell where the call goes *and* we don't want to
1033 // add metadata to it.
1034 if (CalleeSP == nullptr && CallTarget.getReg() == 0 &&
1035 AllocSiteTy == nullptr)
1036 continue;
1037
1038 // TODO: Omit call site entries for runtime calls (objc_msgSend, etc).
1039
1040 bool IsTail = TII->isTailCall(MI);
1041
1042 // If MI is in a bundle, the label was created after the bundle since
1043 // EmitFunctionBody iterates over top-level MIs. Get that top-level MI
1044 // to search for that label below.
1045 const MachineInstr *TopLevelCallMI =
1046 MI.isInsideBundle() ? &*getBundleStart(MI.getIterator()) : &MI;
1047
1048 // For non-tail calls, the return PC is needed to disambiguate paths in
1049 // the call graph which could lead to some target function. For tail
1050 // calls, no return PC information is needed, unless tuning for GDB in
1051 // DWARF4 mode in which case we fake a return PC for compatibility.
1052 const MCSymbol *PCAddr = (!IsTail || CU.useGNUAnalogForDwarf5Feature())
1053 ? getLabelAfterInsn(TopLevelCallMI)
1054 : nullptr;
1055
1056 // For tail calls, it's necessary to record the address of the branch
1057 // instruction so that the debugger can show where the tail call occurred.
1058 const MCSymbol *CallAddr =
1059 IsTail ? getLabelBeforeInsn(TopLevelCallMI) : nullptr;
1060
1061 assert((IsTail || PCAddr) && "Non-tail call without return PC");
1062
1063 LLVM_DEBUG(
1064 dbgs() << "CallSiteEntry: " << MF.getName() << " -> "
1065 << (CalleeDecl
1066 ? CalleeDecl->getName()
1067 : StringRef(
1068 MF.getSubtarget().getRegisterInfo()->getName(
1069 CallTarget.getReg())))
1070 << (IsTail ? " [IsTail]" : "") << "\n");
1071
1072 DIE &CallSiteDIE = CU.constructCallSiteEntryDIE(
1073 ScopeDIE, CalleeSP, CalleeDecl, IsTail, PCAddr, CallAddr, CallTarget,
1074 Offset, AllocSiteTy);
1075
1076 if (CallTarget.getReg())
1077 addCallSiteTargetForIndirectCalls(TopLevelCallMI, CallSiteDIE);
1078
1079 // Optionally emit call-site-param debug info.
1080 if (emitDebugEntryValues()) {
1081 ParamSet Params;
1082 // Try to interpret values of call site parameters.
1083 collectCallSiteParameters(&MI, Params);
1084 CU.constructCallSiteParmEntryDIEs(CallSiteDIE, Params);
1085 }
1086 }
1087 }
1088}
1089
1090void DwarfDebug::addGnuPubAttributes(DwarfCompileUnit &U, DIE &D) const {
1091 if (!U.hasDwarfPubSections())
1092 return;
1093
1094 U.addFlag(D, dwarf::DW_AT_GNU_pubnames);
1095}
1096
1097void DwarfDebug::finishUnitAttributes(const DICompileUnit *DIUnit,
1098 DwarfCompileUnit &NewCU) {
1099 DIE &Die = NewCU.getUnitDie();
1100 StringRef FN = DIUnit->getFilename();
1101
1102 StringRef Producer = DIUnit->getProducer();
1103 StringRef Flags = DIUnit->getFlags();
1104 if (!Flags.empty() && !useAppleExtensionAttributes()) {
1105 std::string ProducerWithFlags = Producer.str() + " " + Flags.str();
1106 NewCU.addString(Die, dwarf::DW_AT_producer, ProducerWithFlags);
1107 } else
1108 NewCU.addString(Die, dwarf::DW_AT_producer, Producer);
1109
1110 if (auto Lang = DIUnit->getSourceLanguage(); Lang.hasVersionedName()) {
1111 NewCU.addUInt(Die, dwarf::DW_AT_language_name, dwarf::DW_FORM_data2,
1112 Lang.getName());
1113
1114 if (uint32_t LangVersion = Lang.getVersion(); LangVersion != 0)
1115 NewCU.addUInt(Die, dwarf::DW_AT_language_version, /*Form=*/std::nullopt,
1116 LangVersion);
1117 } else {
1118 NewCU.addUInt(Die, dwarf::DW_AT_language, dwarf::DW_FORM_data2,
1119 Lang.getName());
1120 }
1121
1122 NewCU.addString(Die, dwarf::DW_AT_name, FN);
1123
1124 finishTargetUnitAttributes(*DIUnit, NewCU);
1125
1126 StringRef SysRoot = DIUnit->getSysRoot();
1127 if (!SysRoot.empty())
1128 NewCU.addString(Die, dwarf::DW_AT_LLVM_sysroot, SysRoot);
1129 StringRef SDK = DIUnit->getSDK();
1130 if (!SDK.empty())
1131 NewCU.addString(Die, dwarf::DW_AT_APPLE_sdk, SDK);
1132
1133 if (!useSplitDwarf()) {
1134 // Add DW_str_offsets_base to the unit DIE, except for split units.
1136 NewCU.addStringOffsetsStart();
1137
1138 NewCU.initStmtList();
1139
1140 // If we're using split dwarf the compilation dir is going to be in the
1141 // skeleton CU and so we don't need to duplicate it here.
1142 if (!CompilationDir.empty())
1143 NewCU.addString(Die, dwarf::DW_AT_comp_dir, CompilationDir);
1144 addGnuPubAttributes(NewCU, Die);
1145 }
1146
1148 if (DIUnit->isOptimized())
1149 NewCU.addFlag(Die, dwarf::DW_AT_APPLE_optimized);
1150
1151 StringRef Flags = DIUnit->getFlags();
1152 if (!Flags.empty())
1153 NewCU.addString(Die, dwarf::DW_AT_APPLE_flags, Flags);
1154
1155 if (unsigned RVer = DIUnit->getRuntimeVersion())
1156 NewCU.addUInt(Die, dwarf::DW_AT_APPLE_major_runtime_vers,
1157 dwarf::DW_FORM_data1, RVer);
1158 }
1159
1160 if (DIUnit->getDWOId()) {
1161 // This CU is either a clang module DWO or a skeleton CU.
1162 NewCU.addUInt(Die, dwarf::DW_AT_GNU_dwo_id, dwarf::DW_FORM_data8,
1163 DIUnit->getDWOId());
1164 if (!DIUnit->getSplitDebugFilename().empty()) {
1165 // This is a prefabricated skeleton CU.
1166 dwarf::Attribute attrDWOName = getDwarfVersion() >= 5
1167 ? dwarf::DW_AT_dwo_name
1168 : dwarf::DW_AT_GNU_dwo_name;
1169 NewCU.addString(Die, attrDWOName, DIUnit->getSplitDebugFilename());
1170 }
1171 }
1172}
1173
1174DwarfCompileUnit *DwarfDebug::getDwarfCompileUnit(const DICompileUnit *DIUnit) {
1175 if (auto *CU = CUMap.lookup(DIUnit))
1176 return CU;
1177
1178 if (useSplitDwarf() && !shareAcrossDWOCUs() &&
1179 (!DIUnit->getSplitDebugInlining() ||
1181 !CUMap.empty())
1182 return CUMap.begin()->second;
1183
1184 return nullptr;
1185}
1186
1187// Create new DwarfCompileUnit for the given metadata node with tag
1188// DW_TAG_compile_unit.
1190DwarfDebug::getOrCreateDwarfCompileUnit(const DICompileUnit *DIUnit) {
1191 if (auto *CU = getDwarfCompileUnit(DIUnit))
1192 return *CU;
1193
1194 CompilationDir = DIUnit->getDirectory();
1195
1196 auto OwnedUnit = std::make_unique<DwarfCompileUnit>(
1197 InfoHolder.getUnits().size(), DIUnit, Asm, this, &InfoHolder);
1198 DwarfCompileUnit &NewCU = *OwnedUnit;
1199 InfoHolder.addUnit(std::move(OwnedUnit));
1200
1201 // LTO with assembly output shares a single line table amongst multiple CUs.
1202 // To avoid the compilation directory being ambiguous, let the line table
1203 // explicitly describe the directory of all files, never relying on the
1204 // compilation directory.
1205 if (!Asm->OutStreamer->hasRawTextSupport() || SingleCU)
1206 Asm->OutStreamer->emitDwarfFile0Directive(
1207 CompilationDir, DIUnit->getFilename(), getMD5AsBytes(DIUnit->getFile()),
1208 DIUnit->getSource(), NewCU.getUniqueID());
1209
1210 if (useSplitDwarf()) {
1211 NewCU.setSkeleton(constructSkeletonCU(NewCU));
1212 NewCU.setSection(Asm->getObjFileLowering().getDwarfInfoDWOSection());
1213 } else {
1214 finishUnitAttributes(DIUnit, NewCU);
1215 NewCU.setSection(Asm->getObjFileLowering().getDwarfInfoSection());
1216 }
1217
1218 CUMap.insert({DIUnit, &NewCU});
1219 CUDieMap.insert({&NewCU.getUnitDie(), &NewCU});
1220 return NewCU;
1221}
1222
1223/// Sort and unique GVEs by comparing their fragment offset.
1226 llvm::sort(
1228 // Sort order: first null exprs, then exprs without fragment
1229 // info, then sort by fragment offset in bits.
1230 // FIXME: Come up with a more comprehensive comparator so
1231 // the sorting isn't non-deterministic, and so the following
1232 // std::unique call works correctly.
1233 if (!A.Expr || !B.Expr)
1234 return !!B.Expr;
1235 auto FragmentA = A.Expr->getFragmentInfo();
1236 auto FragmentB = B.Expr->getFragmentInfo();
1237 if (!FragmentA || !FragmentB)
1238 return !!FragmentB;
1239 return FragmentA->OffsetInBits < FragmentB->OffsetInBits;
1240 });
1241 GVEs.erase(llvm::unique(GVEs,
1244 return A.Expr == B.Expr;
1245 }),
1246 GVEs.end());
1247 return GVEs;
1248}
1249
1250// Emit all Dwarf sections that should come prior to the content. Create
1251// global DIEs and emit initial debug info sections. This is invoked by
1252// the target AsmPrinter.
1255
1256 if (!Asm)
1257 return;
1258
1259 unsigned NumDebugCUs = std::distance(M->debug_compile_units_begin(),
1260 M->debug_compile_units_end());
1261 if (NumDebugCUs == 0)
1262 return;
1263
1264 assert(NumDebugCUs > 0 && "Asm unexpectedly initialized");
1265 SingleCU = NumDebugCUs == 1;
1266
1267 // Create the symbol that designates the start of the unit's contribution
1268 // to the string offsets table. In a split DWARF scenario, only the skeleton
1269 // unit has the DW_AT_str_offsets_base attribute (and hence needs the symbol).
1271 (useSplitDwarf() ? SkeletonHolder : InfoHolder)
1272 .setStringOffsetsStartSym(Asm->createTempSymbol("str_offsets_base"));
1273
1274
1275 // Create the symbols that designates the start of the DWARF v5 range list
1276 // and locations list tables. They are located past the table headers.
1277 if (getDwarfVersion() >= 5) {
1278 DwarfFile &Holder = useSplitDwarf() ? SkeletonHolder : InfoHolder;
1280 Asm->createTempSymbol("rnglists_table_base"));
1281
1282 if (useSplitDwarf())
1283 InfoHolder.setRnglistsTableBaseSym(
1284 Asm->createTempSymbol("rnglists_dwo_table_base"));
1285 }
1286
1287 // Create the symbol that points to the first entry following the debug
1288 // address table (.debug_addr) header.
1289 AddrPool.setLabel(Asm->createTempSymbol("addr_table_base"));
1290 DebugLocs.setSym(Asm->createTempSymbol("loclists_table_base"));
1291
1292 for (DICompileUnit *CUNode : M->debug_compile_units()) {
1293 if (CUNode->getImportedEntities().empty() &&
1294 CUNode->getEnumTypes().empty() && CUNode->getRetainedTypes().empty() &&
1295 CUNode->getGlobalVariables().empty() && CUNode->getMacros().empty())
1296 continue;
1297
1298 DwarfCompileUnit &CU = getOrCreateDwarfCompileUnit(CUNode);
1299
1300 for (auto *Ty : CUNode->getEnumTypes()) {
1301 assert(!isa_and_nonnull<DILocalScope>(Ty->getScope()) &&
1302 "Unexpected function-local entity in 'enums' CU field.");
1303 CU.getOrCreateTypeDIE(cast<DIType>(Ty));
1304 }
1305
1306 for (auto *Ty : CUNode->getRetainedTypes()) {
1307 if (DIType *RT = dyn_cast<DIType>(Ty))
1308 // There is no point in force-emitting a forward declaration.
1309 CU.getOrCreateTypeDIE(RT);
1310 }
1311 }
1312}
1313
1314void DwarfDebug::finishEntityDefinitions() {
1315 for (const auto &Entity : ConcreteEntities) {
1316 DIE *Die = Entity->getDIE();
1317 assert(Die);
1318 // FIXME: Consider the time-space tradeoff of just storing the unit pointer
1319 // in the ConcreteEntities list, rather than looking it up again here.
1320 // DIE::getUnit isn't simple - it walks parent pointers, etc.
1321 DwarfCompileUnit *Unit = CUDieMap.lookup(Die->getUnitDie());
1322 assert(Unit);
1323 Unit->finishEntityDefinition(Entity.get());
1324 }
1325}
1326
1327void DwarfDebug::finishSubprogramDefinitions() {
1328 for (const DISubprogram *SP : ProcessedSPNodes) {
1329 assert(SP->getUnit()->getEmissionKind() != DICompileUnit::NoDebug);
1330 forBothCUs(
1331 getOrCreateDwarfCompileUnit(SP->getUnit()),
1332 [&](DwarfCompileUnit &CU) { CU.finishSubprogramDefinition(SP); });
1333 }
1334}
1335
1336void DwarfDebug::finalizeModuleInfo() {
1337 const TargetLoweringObjectFile &TLOF = Asm->getObjFileLowering();
1338
1339 finishSubprogramDefinitions();
1340
1341 finishEntityDefinitions();
1342
1343 bool HasEmittedSplitCU = false;
1344
1345 // Handle anything that needs to be done on a per-unit basis after
1346 // all other generation.
1347 for (const auto &P : CUMap) {
1348 auto &TheCU = *P.second;
1349 if (TheCU.getCUNode()->isDebugDirectivesOnly())
1350 continue;
1351 TheCU.attachLexicalScopesAbstractOrigins();
1352 // Emit DW_AT_containing_type attribute to connect types with their
1353 // vtable holding type.
1354 TheCU.constructContainingTypeDIEs();
1355
1356 // Add CU specific attributes if we need to add any.
1357 // If we're splitting the dwarf out now that we've got the entire
1358 // CU then add the dwo id to it.
1359 auto *SkCU = TheCU.getSkeleton();
1360
1361 bool HasSplitUnit = SkCU && !TheCU.getUnitDie().children().empty();
1362
1363 if (HasSplitUnit) {
1364 (void)HasEmittedSplitCU;
1365 assert((shareAcrossDWOCUs() || !HasEmittedSplitCU) &&
1366 "Multiple CUs emitted into a single dwo file");
1367 HasEmittedSplitCU = true;
1368 dwarf::Attribute attrDWOName = getDwarfVersion() >= 5
1369 ? dwarf::DW_AT_dwo_name
1370 : dwarf::DW_AT_GNU_dwo_name;
1371 finishUnitAttributes(TheCU.getCUNode(), TheCU);
1372 StringRef DWOName = Asm->TM.Options.MCOptions.SplitDwarfFile;
1373 TheCU.addString(TheCU.getUnitDie(), attrDWOName, DWOName);
1374 SkCU->addString(SkCU->getUnitDie(), attrDWOName, DWOName);
1375 // Emit a unique identifier for this CU. Include the DWO file name in the
1376 // hash to avoid the case where two (almost) empty compile units have the
1377 // same contents. This can happen if link-time optimization removes nearly
1378 // all (unused) code from a CU.
1379 uint64_t ID =
1380 DIEHash(Asm, &TheCU).computeCUSignature(DWOName, TheCU.getUnitDie());
1381 if (getDwarfVersion() >= 5) {
1382 TheCU.setDWOId(ID);
1383 SkCU->setDWOId(ID);
1384 } else {
1385 TheCU.addUInt(TheCU.getUnitDie(), dwarf::DW_AT_GNU_dwo_id,
1386 dwarf::DW_FORM_data8, ID);
1387 SkCU->addUInt(SkCU->getUnitDie(), dwarf::DW_AT_GNU_dwo_id,
1388 dwarf::DW_FORM_data8, ID);
1389 }
1390
1391 if (getDwarfVersion() < 5 && !SkeletonHolder.getRangeLists().empty()) {
1392 const MCSymbol *Sym = TLOF.getDwarfRangesSection()->getBeginSymbol();
1393 SkCU->addSectionLabel(SkCU->getUnitDie(), dwarf::DW_AT_GNU_ranges_base,
1394 Sym, Sym);
1395 }
1396 } else if (SkCU) {
1397 finishUnitAttributes(SkCU->getCUNode(), *SkCU);
1398 }
1399
1400 // If we have code split among multiple sections or non-contiguous
1401 // ranges of code then emit a DW_AT_ranges attribute on the unit that will
1402 // remain in the .o file, otherwise add a DW_AT_low_pc.
1403 // FIXME: We should use ranges allow reordering of code ala
1404 // .subsections_via_symbols in mach-o. This would mean turning on
1405 // ranges for all subprogram DIEs for mach-o.
1406 DwarfCompileUnit &U = SkCU ? *SkCU : TheCU;
1407
1408 if (unsigned NumRanges = TheCU.getRanges().size()) {
1410 if (NumRanges > 1 && useRangesSection())
1411 // A DW_AT_low_pc attribute may also be specified in combination with
1412 // DW_AT_ranges to specify the default base address for use in
1413 // location lists (see Section 2.6.2) and range lists (see Section
1414 // 2.17.3).
1415 U.addUInt(U.getUnitDie(), dwarf::DW_AT_low_pc, dwarf::DW_FORM_addr,
1416 0);
1417 else
1418 U.setBaseAddress(TheCU.getRanges().front().Begin);
1419 U.attachRangesOrLowHighPC(U.getUnitDie(), TheCU.takeRanges());
1420 }
1421 }
1422
1423 // We don't keep track of which addresses are used in which CU so this
1424 // is a bit pessimistic under LTO.
1425 if ((HasSplitUnit || getDwarfVersion() >= 5) && !AddrPool.isEmpty())
1426 U.addAddrTableBase();
1427
1428 if (getDwarfVersion() >= 5) {
1429 if (U.hasRangeLists())
1430 U.addRnglistsBase();
1431
1432 if (!DebugLocs.getLists().empty() && !useSplitDwarf()) {
1433 U.addSectionLabel(U.getUnitDie(), dwarf::DW_AT_loclists_base,
1434 DebugLocs.getSym(),
1436 }
1437 }
1438
1439 auto *CUNode = cast<DICompileUnit>(P.first);
1440 // If compile Unit has macros, emit "DW_AT_macro_info/DW_AT_macros"
1441 // attribute.
1442 if (CUNode->getMacros()) {
1443 if (UseDebugMacroSection) {
1444 if (useSplitDwarf())
1445 TheCU.addSectionDelta(
1446 TheCU.getUnitDie(), dwarf::DW_AT_macros, U.getMacroLabelBegin(),
1448 else {
1449 dwarf::Attribute MacrosAttr = getDwarfVersion() >= 5
1450 ? dwarf::DW_AT_macros
1451 : dwarf::DW_AT_GNU_macros;
1452 U.addSectionLabel(U.getUnitDie(), MacrosAttr, U.getMacroLabelBegin(),
1454 }
1455 } else {
1456 if (useSplitDwarf())
1457 TheCU.addSectionDelta(
1458 TheCU.getUnitDie(), dwarf::DW_AT_macro_info,
1459 U.getMacroLabelBegin(),
1461 else
1462 U.addSectionLabel(U.getUnitDie(), dwarf::DW_AT_macro_info,
1463 U.getMacroLabelBegin(),
1465 }
1466 }
1467 }
1468
1469 // Emit all frontend-produced Skeleton CUs, i.e., Clang modules.
1470 for (auto *CUNode : MMI->getModule()->debug_compile_units())
1471 if (CUNode->getDWOId())
1472 getOrCreateDwarfCompileUnit(CUNode);
1473
1474 // Compute DIE offsets and sizes.
1475 InfoHolder.computeSizeAndOffsets();
1476 if (useSplitDwarf())
1477 SkeletonHolder.computeSizeAndOffsets();
1478
1479 // Now that offsets are computed, can replace DIEs in debug_names Entry with
1480 // an actual offset.
1481 AccelDebugNames.convertDieToOffset();
1482}
1483
1484// Emit all Dwarf sections that should come after the content.
1486 // Terminate the pending line table.
1487 if (PrevCU)
1488 terminateLineTable(PrevCU);
1489 PrevCU = nullptr;
1490 assert(CurFn == nullptr);
1491 assert(CurMI == nullptr);
1492
1493 const Module *M = MMI->getModule();
1494
1495 // Collect global variables info.
1497 GVMap;
1498 for (const GlobalVariable &Global : M->globals()) {
1500 Global.getDebugInfo(GVs);
1501 for (auto *GVE : GVs)
1502 GVMap[GVE->getVariable()].push_back({&Global, GVE->getExpression()});
1503 }
1504
1505 for (DICompileUnit *CUNode : M->debug_compile_units()) {
1506 DwarfCompileUnit *CU = getDwarfCompileUnit(CUNode);
1507
1508 // If the CU hasn't been emitted yet, it must be empty. Skip it.
1509 if (!CU)
1510 continue;
1511
1512 // Emit Global Variables.
1513 for (auto *GVE : CUNode->getGlobalVariables()) {
1514 // Don't bother adding DIGlobalVariableExpressions listed in the CU if we
1515 // already know about the variable and it isn't adding a constant
1516 // expression.
1517 auto &GVMapEntry = GVMap[GVE->getVariable()];
1518 auto *Expr = GVE->getExpression();
1519 if (!GVMapEntry.size() || (Expr && Expr->isConstant()))
1520 GVMapEntry.push_back({nullptr, Expr});
1521 }
1523 for (auto *GVE : CUNode->getGlobalVariables()) {
1524 DIGlobalVariable *GV = GVE->getVariable();
1525 if (Processed.insert(GV).second)
1526 CU->getOrCreateGlobalVariableDIE(GV, sortGlobalExprs(GVMap[GV]));
1527 }
1528
1529 // Emit imported entities.
1530 for (auto *IE : CUNode->getImportedEntities()) {
1531 assert(!isa_and_nonnull<DILocalScope>(IE->getScope()) &&
1532 "Unexpected function-local entity in 'imports' CU field.");
1533 CU->getOrCreateImportedEntityDIE(IE);
1534 }
1535
1536 // Emit function-local entities.
1537 for (const auto *D : CU->getDeferredLocalDecls()) {
1538 if (auto *IE = dyn_cast<DIImportedEntity>(D))
1539 CU->getOrCreateImportedEntityDIE(IE);
1540 else if (auto *Ty = dyn_cast<DIType>(D))
1541 CU->getOrCreateTypeDIE(Ty);
1542 else
1543 llvm_unreachable("Unexpected local retained node!");
1544 }
1545
1546 // Emit base types.
1547 CU->createBaseTypeDIEs();
1548 }
1549
1550 // If we aren't actually generating debug info (check beginModule -
1551 // conditionalized on the presence of the llvm.dbg.cu metadata node)
1552 if (!Asm || !Asm->hasDebugInfo())
1553 return;
1554
1555 // Finalize the debug info for the module.
1556 finalizeModuleInfo();
1557
1558 if (useSplitDwarf())
1559 // Emit debug_loc.dwo/debug_loclists.dwo section.
1560 emitDebugLocDWO();
1561 else
1562 // Emit debug_loc/debug_loclists section.
1563 emitDebugLoc();
1564
1565 // Corresponding abbreviations into a abbrev section.
1566 emitAbbreviations();
1567
1568 // Emit all the DIEs into a debug info section.
1569 emitDebugInfo();
1570
1571 // Emit info into a debug aranges section.
1572 if (UseARangesSection)
1573 emitDebugARanges();
1574
1575 // Emit info into a debug ranges section.
1576 emitDebugRanges();
1577
1578 if (useSplitDwarf())
1579 // Emit info into a debug macinfo.dwo section.
1580 emitDebugMacinfoDWO();
1581 else
1582 // Emit info into a debug macinfo/macro section.
1583 emitDebugMacinfo();
1584
1585 emitDebugStr();
1586
1587 if (useSplitDwarf()) {
1588 emitDebugStrDWO();
1589 emitDebugInfoDWO();
1590 emitDebugAbbrevDWO();
1591 emitDebugLineDWO();
1592 emitDebugRangesDWO();
1593 }
1594
1595 emitDebugAddr();
1596
1597 // Emit info into the dwarf accelerator table sections.
1598 switch (getAccelTableKind()) {
1600 emitAccelNames();
1601 emitAccelObjC();
1602 emitAccelNamespaces();
1603 emitAccelTypes();
1604 break;
1606 emitAccelDebugNames();
1607 break;
1609 break;
1611 llvm_unreachable("Default should have already been resolved.");
1612 }
1613
1614 // Emit the pubnames and pubtypes sections if requested.
1615 emitDebugPubSections();
1616
1617 // clean up.
1618 // FIXME: AbstractVariables.clear();
1619}
1620
1621void DwarfDebug::ensureAbstractEntityIsCreatedIfScoped(DwarfCompileUnit &CU,
1622 const DINode *Node, const MDNode *ScopeNode) {
1623 if (CU.getExistingAbstractEntity(Node))
1624 return;
1625
1626 if (LexicalScope *Scope =
1628 CU.createAbstractEntity(Node, Scope);
1629}
1630
1632 // Ensure the scope is not a DILexicalBlockFile.
1634}
1635
1636// Collect variable information from side table maintained by MF.
1637void DwarfDebug::collectVariableInfoFromMFTable(
1638 DwarfCompileUnit &TheCU, DenseSet<InlinedEntity> &Processed) {
1639 SmallDenseMap<InlinedEntity, DbgVariable *> MFVars;
1640 LLVM_DEBUG(dbgs() << "DwarfDebug: collecting variables from MF side table\n");
1641 for (const auto &VI : Asm->MF->getVariableDbgInfo()) {
1642 if (!VI.Var)
1643 continue;
1644 assert(VI.Var->isValidLocationForIntrinsic(VI.Loc) &&
1645 "Expected inlined-at fields to agree");
1646
1647 InlinedEntity Var(VI.Var, VI.Loc->getInlinedAt());
1648 Processed.insert(Var);
1649 LexicalScope *Scope = LScopes.findLexicalScope(VI.Loc);
1650
1651 // If variable scope is not found then skip this variable.
1652 if (!Scope) {
1653 LLVM_DEBUG(dbgs() << "Dropping debug info for " << VI.Var->getName()
1654 << ", no variable scope found\n");
1655 continue;
1656 }
1657
1658 ensureAbstractEntityIsCreatedIfScoped(TheCU, Var.first, Scope->getScopeNode());
1659
1660 // If we have already seen information for this variable, add to what we
1661 // already know.
1662 if (DbgVariable *PreviousLoc = MFVars.lookup(Var)) {
1663 auto *PreviousMMI = std::get_if<Loc::MMI>(PreviousLoc);
1664 auto *PreviousEntryValue = std::get_if<Loc::EntryValue>(PreviousLoc);
1665 // Previous and new locations are both stack slots (MMI).
1666 if (PreviousMMI && VI.inStackSlot())
1667 PreviousMMI->addFrameIndexExpr(VI.Expr, VI.getStackSlot());
1668 // Previous and new locations are both entry values.
1669 else if (PreviousEntryValue && VI.inEntryValueRegister())
1670 PreviousEntryValue->addExpr(VI.getEntryValueRegister(), *VI.Expr);
1671 else {
1672 // Locations differ, this should (rarely) happen in optimized async
1673 // coroutines.
1674 // Prefer whichever location has an EntryValue.
1675 if (PreviousLoc->holds<Loc::MMI>())
1676 PreviousLoc->emplace<Loc::EntryValue>(VI.getEntryValueRegister(),
1677 *VI.Expr);
1678 LLVM_DEBUG(dbgs() << "Dropping debug info for " << VI.Var->getName()
1679 << ", conflicting fragment location types\n");
1680 }
1681 continue;
1682 }
1683
1684 auto RegVar = std::make_unique<DbgVariable>(
1685 cast<DILocalVariable>(Var.first), Var.second);
1686 if (VI.inStackSlot())
1687 RegVar->emplace<Loc::MMI>(VI.Expr, VI.getStackSlot());
1688 else
1689 RegVar->emplace<Loc::EntryValue>(VI.getEntryValueRegister(), *VI.Expr);
1690 LLVM_DEBUG(dbgs() << "Created DbgVariable for " << VI.Var->getName()
1691 << "\n");
1692 InfoHolder.addScopeVariable(Scope, RegVar.get());
1693 MFVars.insert({Var, RegVar.get()});
1694 ConcreteEntities.push_back(std::move(RegVar));
1695 }
1696}
1697
1698/// Determine whether a *singular* DBG_VALUE is valid for the entirety of its
1699/// enclosing lexical scope. The check ensures there are no other instructions
1700/// in the same lexical scope preceding the DBG_VALUE and that its range is
1701/// either open or otherwise rolls off the end of the scope.
1702static bool validThroughout(LexicalScopes &LScopes,
1703 const MachineInstr *DbgValue,
1704 const MachineInstr *RangeEnd,
1705 const InstructionOrdering &Ordering) {
1706 assert(DbgValue->getDebugLoc() && "DBG_VALUE without a debug location");
1707 auto MBB = DbgValue->getParent();
1708 auto DL = DbgValue->getDebugLoc();
1709 auto *LScope = LScopes.findLexicalScope(DL);
1710 // Scope doesn't exist; this is a dead DBG_VALUE.
1711 if (!LScope)
1712 return false;
1713 auto &LSRange = LScope->getRanges();
1714 if (LSRange.size() == 0)
1715 return false;
1716
1717 const MachineInstr *LScopeBegin = LSRange.front().first;
1718 // If the scope starts before the DBG_VALUE then we may have a negative
1719 // result. Otherwise the location is live coming into the scope and we
1720 // can skip the following checks.
1721 if (!Ordering.isBefore(DbgValue, LScopeBegin)) {
1722 // Exit if the lexical scope begins outside of the current block.
1723 if (LScopeBegin->getParent() != MBB)
1724 return false;
1725
1727 for (++Pred; Pred != MBB->rend(); ++Pred) {
1728 if (Pred->getFlag(MachineInstr::FrameSetup))
1729 break;
1730 auto PredDL = Pred->getDebugLoc();
1731 if (!PredDL || Pred->isMetaInstruction())
1732 continue;
1733 // Check whether the instruction preceding the DBG_VALUE is in the same
1734 // (sub)scope as the DBG_VALUE.
1735 if (DL->getScope() == PredDL->getScope())
1736 return false;
1737 auto *PredScope = LScopes.findLexicalScope(PredDL);
1738 if (!PredScope || LScope->dominates(PredScope))
1739 return false;
1740 }
1741 }
1742
1743 // If the range of the DBG_VALUE is open-ended, report success.
1744 if (!RangeEnd)
1745 return true;
1746
1747 // Single, constant DBG_VALUEs in the prologue are promoted to be live
1748 // throughout the function. This is a hack, presumably for DWARF v2 and not
1749 // necessarily correct. It would be much better to use a dbg.declare instead
1750 // if we know the constant is live throughout the scope.
1751 if (MBB->pred_empty() &&
1752 all_of(DbgValue->debug_operands(),
1753 [](const MachineOperand &Op) { return Op.isImm(); }))
1754 return true;
1755
1756 // Test if the location terminates before the end of the scope.
1757 const MachineInstr *LScopeEnd = LSRange.back().second;
1758 if (Ordering.isBefore(RangeEnd, LScopeEnd))
1759 return false;
1760
1761 // There's a single location which starts at the scope start, and ends at or
1762 // after the scope end.
1763 return true;
1764}
1765
1766/// Build the location list for all DBG_VALUEs in the function that
1767/// describe the same variable. The resulting DebugLocEntries will have
1768/// strict monotonically increasing begin addresses and will never
1769/// overlap. If the resulting list has only one entry that is valid
1770/// throughout variable's scope return true.
1771//
1772// See the definition of DbgValueHistoryMap::Entry for an explanation of the
1773// different kinds of history map entries. One thing to be aware of is that if
1774// a debug value is ended by another entry (rather than being valid until the
1775// end of the function), that entry's instruction may or may not be included in
1776// the range, depending on if the entry is a clobbering entry (it has an
1777// instruction that clobbers one or more preceding locations), or if it is an
1778// (overlapping) debug value entry. This distinction can be seen in the example
1779// below. The first debug value is ended by the clobbering entry 2, and the
1780// second and third debug values are ended by the overlapping debug value entry
1781// 4.
1782//
1783// Input:
1784//
1785// History map entries [type, end index, mi]
1786//
1787// 0 | [DbgValue, 2, DBG_VALUE $reg0, [...] (fragment 0, 32)]
1788// 1 | | [DbgValue, 4, DBG_VALUE $reg1, [...] (fragment 32, 32)]
1789// 2 | | [Clobber, $reg0 = [...], -, -]
1790// 3 | | [DbgValue, 4, DBG_VALUE 123, [...] (fragment 64, 32)]
1791// 4 [DbgValue, ~0, DBG_VALUE @g, [...] (fragment 0, 96)]
1792//
1793// Output [start, end) [Value...]:
1794//
1795// [0-1) [(reg0, fragment 0, 32)]
1796// [1-3) [(reg0, fragment 0, 32), (reg1, fragment 32, 32)]
1797// [3-4) [(reg1, fragment 32, 32), (123, fragment 64, 32)]
1798// [4-) [(@g, fragment 0, 96)]
1799bool DwarfDebug::buildLocationList(SmallVectorImpl<DebugLocEntry> &DebugLoc,
1800 const DbgValueHistoryMap::Entries &Entries) {
1801 using OpenRange =
1802 std::pair<DbgValueHistoryMap::EntryIndex, DbgValueLoc>;
1803 SmallVector<OpenRange, 4> OpenRanges;
1804 bool isSafeForSingleLocation = true;
1805 const MachineInstr *StartDebugMI = nullptr;
1806 const MachineInstr *EndMI = nullptr;
1807
1808 for (auto EB = Entries.begin(), EI = EB, EE = Entries.end(); EI != EE; ++EI) {
1809 const MachineInstr *Instr = EI->getInstr();
1810
1811 // Remove all values that are no longer live.
1812 size_t Index = std::distance(EB, EI);
1813 erase_if(OpenRanges, [&](OpenRange &R) { return R.first <= Index; });
1814
1815 // If we are dealing with a clobbering entry, this iteration will result in
1816 // a location list entry starting after the clobbering instruction.
1817 const MCSymbol *StartLabel =
1818 EI->isClobber() ? getLabelAfterInsn(Instr) : getLabelBeforeInsn(Instr);
1819 assert(StartLabel &&
1820 "Forgot label before/after instruction starting a range!");
1821
1822 const MCSymbol *EndLabel;
1823 if (std::next(EI) == Entries.end()) {
1824 const MachineBasicBlock &EndMBB = Asm->MF->back();
1825 EndLabel = Asm->MBBSectionRanges[EndMBB.getSectionID()].EndLabel;
1826 if (EI->isClobber())
1827 EndMI = EI->getInstr();
1828 }
1829 else if (std::next(EI)->isClobber())
1830 EndLabel = getLabelAfterInsn(std::next(EI)->getInstr());
1831 else
1832 EndLabel = getLabelBeforeInsn(std::next(EI)->getInstr());
1833 assert(EndLabel && "Forgot label after instruction ending a range!");
1834
1835 if (EI->isDbgValue())
1836 LLVM_DEBUG(dbgs() << "DotDebugLoc: " << *Instr << "\n");
1837
1838 // If this history map entry has a debug value, add that to the list of
1839 // open ranges and check if its location is valid for a single value
1840 // location.
1841 if (EI->isDbgValue()) {
1842 // Do not add undef debug values, as they are redundant information in
1843 // the location list entries. An undef debug results in an empty location
1844 // description. If there are any non-undef fragments then padding pieces
1845 // with empty location descriptions will automatically be inserted, and if
1846 // all fragments are undef then the whole location list entry is
1847 // redundant.
1848 if (!Instr->isUndefDebugValue()) {
1849 auto Value = getDebugLocValue(Instr);
1850 OpenRanges.emplace_back(EI->getEndIndex(), Value);
1851
1852 // TODO: Add support for single value fragment locations.
1853 if (Instr->getDebugExpression()->isFragment())
1854 isSafeForSingleLocation = false;
1855
1856 if (!StartDebugMI)
1857 StartDebugMI = Instr;
1858 } else {
1859 isSafeForSingleLocation = false;
1860 }
1861 }
1862
1863 // Location list entries with empty location descriptions are redundant
1864 // information in DWARF, so do not emit those.
1865 if (OpenRanges.empty())
1866 continue;
1867
1868 // Omit entries with empty ranges as they do not have any effect in DWARF.
1869 if (StartLabel == EndLabel) {
1870 LLVM_DEBUG(dbgs() << "Omitting location list entry with empty range.\n");
1871 continue;
1872 }
1873
1875 for (auto &R : OpenRanges)
1876 Values.push_back(R.second);
1877
1878 // With Basic block sections, it is posssible that the StartLabel and the
1879 // Instr are not in the same section. This happens when the StartLabel is
1880 // the function begin label and the dbg value appears in a basic block
1881 // that is not the entry. In this case, the range needs to be split to
1882 // span each individual section in the range from StartLabel to EndLabel.
1883 if (Asm->MF->hasBBSections() && StartLabel == Asm->getFunctionBegin() &&
1884 !Instr->getParent()->sameSection(&Asm->MF->front())) {
1885 for (const auto &[MBBSectionId, MBBSectionRange] :
1886 Asm->MBBSectionRanges) {
1887 if (Instr->getParent()->getSectionID() == MBBSectionId) {
1888 DebugLoc.emplace_back(MBBSectionRange.BeginLabel, EndLabel, Values);
1889 break;
1890 }
1891 DebugLoc.emplace_back(MBBSectionRange.BeginLabel,
1892 MBBSectionRange.EndLabel, Values);
1893 }
1894 } else {
1895 DebugLoc.emplace_back(StartLabel, EndLabel, Values);
1896 }
1897
1898 // Attempt to coalesce the ranges of two otherwise identical
1899 // DebugLocEntries.
1900 auto CurEntry = DebugLoc.rbegin();
1901 LLVM_DEBUG({
1902 dbgs() << CurEntry->getValues().size() << " Values:\n";
1903 for (auto &Value : CurEntry->getValues())
1904 Value.dump();
1905 dbgs() << "-----\n";
1906 });
1907
1908 auto PrevEntry = std::next(CurEntry);
1909 if (PrevEntry != DebugLoc.rend() && PrevEntry->MergeRanges(*CurEntry))
1910 DebugLoc.pop_back();
1911 }
1912
1913 if (!isSafeForSingleLocation ||
1914 !validThroughout(LScopes, StartDebugMI, EndMI, getInstOrdering()))
1915 return false;
1916
1917 if (DebugLoc.size() == 1)
1918 return true;
1919
1920 if (!Asm->MF->hasBBSections())
1921 return false;
1922
1923 // Check here to see if loclist can be merged into a single range. If not,
1924 // we must keep the split loclists per section. This does exactly what
1925 // MergeRanges does without sections. We don't actually merge the ranges
1926 // as the split ranges must be kept intact if this cannot be collapsed
1927 // into a single range.
1928 const MachineBasicBlock *RangeMBB = nullptr;
1929 if (DebugLoc[0].getBeginSym() == Asm->getFunctionBegin())
1930 RangeMBB = &Asm->MF->front();
1931 else
1932 RangeMBB = Entries.begin()->getInstr()->getParent();
1933 auto RangeIt = Asm->MBBSectionRanges.find(RangeMBB->getSectionID());
1934 assert(RangeIt != Asm->MBBSectionRanges.end() &&
1935 "Range MBB not found in MBBSectionRanges!");
1936 auto *CurEntry = DebugLoc.begin();
1937 auto *NextEntry = std::next(CurEntry);
1938 auto NextRangeIt = std::next(RangeIt);
1939 while (NextEntry != DebugLoc.end()) {
1940 if (NextRangeIt == Asm->MBBSectionRanges.end())
1941 return false;
1942 // CurEntry should end the current section and NextEntry should start
1943 // the next section and the Values must match for these two ranges to be
1944 // merged. Do not match the section label end if it is the entry block
1945 // section. This is because the end label for the Debug Loc and the
1946 // Function end label could be different.
1947 if ((RangeIt->second.EndLabel != Asm->getFunctionEnd() &&
1948 CurEntry->getEndSym() != RangeIt->second.EndLabel) ||
1949 NextEntry->getBeginSym() != NextRangeIt->second.BeginLabel ||
1950 CurEntry->getValues() != NextEntry->getValues())
1951 return false;
1952 RangeIt = NextRangeIt;
1953 NextRangeIt = std::next(RangeIt);
1954 CurEntry = NextEntry;
1955 NextEntry = std::next(CurEntry);
1956 }
1957 return true;
1958}
1959
1960DbgEntity *DwarfDebug::createConcreteEntity(DwarfCompileUnit &TheCU,
1961 LexicalScope &Scope,
1962 const DINode *Node,
1963 const DILocation *Location,
1964 const MCSymbol *Sym) {
1965 ensureAbstractEntityIsCreatedIfScoped(TheCU, Node, Scope.getScopeNode());
1966 if (isa<const DILocalVariable>(Node)) {
1967 ConcreteEntities.push_back(
1968 std::make_unique<DbgVariable>(cast<const DILocalVariable>(Node),
1969 Location));
1970 InfoHolder.addScopeVariable(&Scope,
1971 cast<DbgVariable>(ConcreteEntities.back().get()));
1972 } else if (isa<const DILabel>(Node)) {
1973 ConcreteEntities.push_back(
1974 std::make_unique<DbgLabel>(cast<const DILabel>(Node),
1975 Location, Sym));
1976 InfoHolder.addScopeLabel(&Scope,
1977 cast<DbgLabel>(ConcreteEntities.back().get()));
1978 }
1979 return ConcreteEntities.back().get();
1980}
1981
1982// Find variables for each lexical scope.
1983void DwarfDebug::collectEntityInfo(DwarfCompileUnit &TheCU,
1984 const DISubprogram *SP,
1985 DenseSet<InlinedEntity> &Processed) {
1986 // Grab the variable info that was squirreled away in the MMI side-table.
1987 collectVariableInfoFromMFTable(TheCU, Processed);
1988
1989 for (const auto &I : DbgValues) {
1990 InlinedEntity IV = I.first;
1991 if (Processed.count(IV))
1992 continue;
1993
1994 // Instruction ranges, specifying where IV is accessible.
1995 const auto &HistoryMapEntries = I.second;
1996
1997 // Try to find any non-empty variable location. Do not create a concrete
1998 // entity if there are no locations.
1999 if (!DbgValues.hasNonEmptyLocation(HistoryMapEntries))
2000 continue;
2001
2002 LexicalScope *Scope = nullptr;
2003 const DILocalVariable *LocalVar = cast<DILocalVariable>(IV.first);
2004 if (const DILocation *IA = IV.second)
2005 Scope = LScopes.findInlinedScope(LocalVar->getScope(), IA);
2006 else
2007 Scope = LScopes.findLexicalScope(LocalVar->getScope());
2008 // If variable scope is not found then skip this variable.
2009 if (!Scope)
2010 continue;
2011
2012 Processed.insert(IV);
2013 DbgVariable *RegVar = cast<DbgVariable>(createConcreteEntity(TheCU,
2014 *Scope, LocalVar, IV.second));
2015
2016 const MachineInstr *MInsn = HistoryMapEntries.front().getInstr();
2017 assert(MInsn->isDebugValue() && "History must begin with debug value");
2018
2019 // Check if there is a single DBG_VALUE, valid throughout the var's scope.
2020 // If the history map contains a single debug value, there may be an
2021 // additional entry which clobbers the debug value.
2022 size_t HistSize = HistoryMapEntries.size();
2023 bool SingleValueWithClobber =
2024 HistSize == 2 && HistoryMapEntries[1].isClobber();
2025 if (HistSize == 1 || SingleValueWithClobber) {
2026 const auto *End =
2027 SingleValueWithClobber ? HistoryMapEntries[1].getInstr() : nullptr;
2028 if (validThroughout(LScopes, MInsn, End, getInstOrdering())) {
2029 RegVar->emplace<Loc::Single>(MInsn);
2030 continue;
2031 }
2032 }
2033
2034 // Handle multiple DBG_VALUE instructions describing one variable.
2035 DebugLocStream::ListBuilder List(DebugLocs, TheCU, *Asm, *RegVar);
2036
2037 // Build the location list for this variable.
2039 bool isValidSingleLocation = buildLocationList(Entries, HistoryMapEntries);
2040
2041 // Check whether buildLocationList managed to merge all locations to one
2042 // that is valid throughout the variable's scope. If so, produce single
2043 // value location.
2044 if (isValidSingleLocation) {
2045 RegVar->emplace<Loc::Single>(Entries[0].getValues()[0]);
2046 continue;
2047 }
2048
2049 // If the variable has a DIBasicType, extract it. Basic types cannot have
2050 // unique identifiers, so don't bother resolving the type with the
2051 // identifier map.
2052 const DIBasicType *BT = dyn_cast<DIBasicType>(
2053 static_cast<const Metadata *>(LocalVar->getType()));
2054
2055 // Finalize the entry by lowering it into a DWARF bytestream.
2056 for (auto &Entry : Entries)
2057 Entry.finalize(*Asm, List, BT, TheCU);
2058 }
2059
2060 // For each InlinedEntity collected from DBG_LABEL instructions, convert to
2061 // DWARF-related DbgLabel.
2062 for (const auto &I : DbgLabels) {
2063 InlinedEntity IL = I.first;
2064 const MachineInstr *MI = I.second;
2065 if (MI == nullptr)
2066 continue;
2067
2068 LexicalScope *Scope = nullptr;
2069 const DILabel *Label = cast<DILabel>(IL.first);
2070 // The scope could have an extra lexical block file.
2071 const DILocalScope *LocalScope =
2072 Label->getScope()->getNonLexicalBlockFileScope();
2073 // Get inlined DILocation if it is inlined label.
2074 if (const DILocation *IA = IL.second)
2075 Scope = LScopes.findInlinedScope(LocalScope, IA);
2076 else
2077 Scope = LScopes.findLexicalScope(LocalScope);
2078 // If label scope is not found then skip this label.
2079 if (!Scope)
2080 continue;
2081
2082 Processed.insert(IL);
2083 /// At this point, the temporary label is created.
2084 /// Save the temporary label to DbgLabel entity to get the
2085 /// actually address when generating Dwarf DIE.
2087 createConcreteEntity(TheCU, *Scope, Label, IL.second, Sym);
2088 }
2089
2090 // Collect info for retained nodes.
2091 for (const DINode *DN : SP->getRetainedNodes()) {
2092 const auto *LS = getRetainedNodeScope(DN);
2093 if (isa<DILocalVariable>(DN) || isa<DILabel>(DN)) {
2094 if (!Processed.insert(InlinedEntity(DN, nullptr)).second)
2095 continue;
2096 LexicalScope *LexS = LScopes.findLexicalScope(LS);
2097 if (LexS)
2098 createConcreteEntity(TheCU, *LexS, DN, nullptr);
2099 } else {
2100 LocalDeclsPerLS[LS].insert(DN);
2101 }
2102 }
2103}
2104
2105// Process beginning of an instruction.
2107 const MachineFunction &MF = *MI->getMF();
2108 const auto *SP = MF.getFunction().getSubprogram();
2109 bool NoDebug =
2110 !SP || SP->getUnit()->getEmissionKind() == DICompileUnit::NoDebug;
2111
2112 // Delay slot support check.
2113 auto delaySlotSupported = [](const MachineInstr &MI) {
2114 if (!MI.isBundledWithSucc())
2115 return false;
2116 auto Suc = std::next(MI.getIterator());
2117 (void)Suc;
2118 // Ensure that delay slot instruction is successor of the call instruction.
2119 // Ex. CALL_INSTRUCTION {
2120 // DELAY_SLOT_INSTRUCTION }
2121 assert(Suc->isBundledWithPred() &&
2122 "Call bundle instructions are out of order");
2123 return true;
2124 };
2125
2126 // When describing calls, we need a label for the call instruction.
2127 if (!NoDebug && SP->areAllCallsDescribed() &&
2128 MI->isCandidateForAdditionalCallInfo(MachineInstr::AnyInBundle) &&
2129 (!MI->hasDelaySlot() || delaySlotSupported(*MI))) {
2131 bool IsTail = TII->isTailCall(*MI);
2132 // For tail calls, we need the address of the branch instruction for
2133 // DW_AT_call_pc.
2134 if (IsTail)
2136 // For non-tail calls, we need the return address for the call for
2137 // DW_AT_call_return_pc. Under GDB tuning, this information is needed for
2138 // tail calls as well.
2140 }
2141
2143 if (!CurMI)
2144 return;
2145
2146 if (NoDebug)
2147 return;
2148
2149 auto RecordLineZero = [&]() {
2150 // Preserve the file and column numbers, if we can, to save space in
2151 // the encoded line table.
2152 // Do not update PrevInstLoc, it remembers the last non-0 line.
2153 const MDNode *Scope = nullptr;
2154 unsigned Column = 0;
2155 if (PrevInstLoc) {
2156 Scope = PrevInstLoc.getScope();
2157 Column = PrevInstLoc.getCol();
2158 }
2159 recordSourceLine(/*Line=*/0, Column, Scope, /*Flags=*/0);
2160 };
2161
2162 // When we emit a line-0 record, we don't update PrevInstLoc; so look at
2163 // the last line number actually emitted, to see if it was line 0.
2164 unsigned LastAsmLine =
2165 Asm->OutStreamer->getContext().getCurrentDwarfLoc().getLine();
2166
2167 // Check if source location changes, but ignore DBG_VALUE and CFI locations.
2168 // If the instruction is part of the function frame setup code, do not emit
2169 // any line record, as there is no correspondence with any user code.
2170 if (MI->isMetaInstruction())
2171 return;
2172 if (MI->getFlag(MachineInstr::FrameSetup)) {
2173 // Prevent a loc from the previous block leaking into frame setup instrs.
2174 if (LastAsmLine && PrevInstBB && PrevInstBB != MI->getParent())
2175 RecordLineZero();
2176 return;
2177 }
2178
2179 const DebugLoc &DL = MI->getDebugLoc();
2180 unsigned Flags = 0;
2181
2182 if (MI->getFlag(MachineInstr::FrameDestroy) && DL) {
2183 const MachineBasicBlock *MBB = MI->getParent();
2184 if (MBB && (MBB != EpilogBeginBlock)) {
2185 // First time FrameDestroy has been seen in this basic block
2188 }
2189 }
2190
2191 auto RecordSourceLine = [this](auto &DL, auto Flags) {
2192 SmallString<128> LocationString;
2193 if (Asm->OutStreamer->isVerboseAsm()) {
2194 raw_svector_ostream OS(LocationString);
2195 DL.print(OS);
2196 }
2197 recordSourceLine(DL.getLine(), DL.getCol(), DL.getScope(), Flags,
2198 LocationString);
2199 };
2200
2201 // There may be a mixture of scopes using and not using Key Instructions.
2202 // Not-Key-Instructions functions inlined into Key Instructions functions
2203 // should use not-key is_stmt handling. Key Instructions functions inlined
2204 // into Not-Key-Instructions functions should use Key Instructions is_stmt
2205 // handling.
2206 bool ScopeUsesKeyInstructions =
2208 DL->getScope()->getSubprogram()->getKeyInstructionsEnabled();
2209
2210 bool IsKey = false;
2211 if (ScopeUsesKeyInstructions && DL && DL.getLine())
2212 IsKey = KeyInstructions.contains(MI);
2213
2214 if (!DL && MI == PrologEndLoc) {
2215 // In rare situations, we might want to place the end of the prologue
2216 // somewhere that doesn't have a source location already. It should be in
2217 // the entry block.
2218 assert(MI->getParent() == &*MI->getMF()->begin());
2219 recordSourceLine(SP->getScopeLine(), 0, SP,
2221 return;
2222 }
2223
2224 bool PrevInstInSameSection =
2225 (!PrevInstBB ||
2226 PrevInstBB->getSectionID() == MI->getParent()->getSectionID());
2227 bool ForceIsStmt = ForceIsStmtInstrs.contains(MI);
2228 if (PrevInstInSameSection && !ForceIsStmt && DL.isSameSourceLocation(PrevInstLoc)) {
2229 // If we have an ongoing unspecified location, nothing to do here.
2230 if (!DL)
2231 return;
2232
2233 // Skip this if the instruction is Key, else we might accidentally miss an
2234 // is_stmt.
2235 if (!IsKey) {
2236 // We have an explicit location, same as the previous location.
2237 // But we might be coming back to it after a line 0 record.
2238 if ((LastAsmLine == 0 && DL.getLine() != 0) || Flags) {
2239 // Reinstate the source location but not marked as a statement.
2240 RecordSourceLine(DL, Flags);
2241 }
2242 return;
2243 }
2244 }
2245
2246 if (!DL) {
2247 // FIXME: We could assert that `DL.getKind() != DebugLocKind::Temporary`
2248 // here, or otherwise record any temporary DebugLocs seen to ensure that
2249 // transient compiler-generated instructions aren't leaking their DLs to
2250 // other instructions.
2251 // We have an unspecified location, which might want to be line 0.
2252 // If we have already emitted a line-0 record, don't repeat it.
2253 if (LastAsmLine == 0)
2254 return;
2255 // If user said Don't Do That, don't do that.
2257 return;
2258 // See if we have a reason to emit a line-0 record now.
2259 // Reasons to emit a line-0 record include:
2260 // - User asked for it (UnknownLocations).
2261 // - Instruction has a label, so it's referenced from somewhere else,
2262 // possibly debug information; we want it to have a source location.
2263 // - Instruction is at the top of a block; we don't want to inherit the
2264 // location from the physically previous (maybe unrelated) block.
2265 if (UnknownLocations == Enable || PrevLabel ||
2266 (PrevInstBB && PrevInstBB != MI->getParent()))
2267 RecordLineZero();
2268 return;
2269 }
2270
2271 // We have an explicit location, different from the previous location.
2272 // Don't repeat a line-0 record, but otherwise emit the new location.
2273 // (The new location might be an explicit line 0, which we do emit.)
2274 if (DL.getLine() == 0 && LastAsmLine == 0)
2275 return;
2276 if (MI == PrologEndLoc) {
2278 PrologEndLoc = nullptr;
2279 }
2280
2281 if (ScopeUsesKeyInstructions) {
2282 if (IsKey)
2283 Flags |= DWARF2_FLAG_IS_STMT;
2284 } else {
2285 // If the line changed, we call that a new statement; unless we went to
2286 // line 0 and came back, in which case it is not a new statement.
2287 unsigned OldLine = PrevInstLoc ? PrevInstLoc.getLine() : LastAsmLine;
2288 if (DL.getLine() && (DL.getLine() != OldLine || ForceIsStmt))
2289 Flags |= DWARF2_FLAG_IS_STMT;
2290 }
2291
2292 // Call target-specific source line recording.
2293 recordTargetSourceLine(DL, Flags);
2294
2295 // If we're not at line 0, remember this location.
2296 if (DL.getLine())
2297 PrevInstLoc = DL;
2298}
2299
2300/// Default implementation of target-specific source line recording.
2301void DwarfDebug::recordTargetSourceLine(const DebugLoc &DL, unsigned Flags) {
2302 SmallString<128> LocationString;
2303 if (Asm->OutStreamer->isVerboseAsm()) {
2304 raw_svector_ostream OS(LocationString);
2305 DL.print(OS);
2306 }
2307 recordSourceLine(DL.getLine(), DL.getCol(), DL.getScope(), Flags,
2308 LocationString);
2309}
2310
2311// Returns the position where we should place prologue_end, potentially nullptr,
2312// which means "no good place to put prologue_end". Returns true in the second
2313// return value if there are no setup instructions in this function at all,
2314// meaning we should not emit a start-of-function linetable entry, because it
2315// would be zero-lengthed.
2316static std::pair<const MachineInstr *, bool>
2318 // First known non-DBG_VALUE and non-frame setup location marks
2319 // the beginning of the function body.
2320 const auto &TII = *MF->getSubtarget().getInstrInfo();
2321 const MachineInstr *NonTrivialInst = nullptr;
2322 const Function &F = MF->getFunction();
2323 DISubprogram *SP = const_cast<DISubprogram *>(F.getSubprogram());
2324
2325 // Some instructions may be inserted into prologue after this function. Must
2326 // keep prologue for these cases.
2327 bool IsEmptyPrologue =
2328 !(F.hasPrologueData() || F.getMetadata(LLVMContext::MD_func_sanitize));
2329
2330 // Helper lambda to examine each instruction and potentially return it
2331 // as the prologue_end point.
2332 auto ExamineInst = [&](const MachineInstr &MI)
2333 -> std::optional<std::pair<const MachineInstr *, bool>> {
2334 // Is this instruction trivial data shuffling or frame-setup?
2335 bool isCopy = (TII.isCopyInstr(MI) ? true : false);
2336 bool isTrivRemat = TII.isTriviallyReMaterializable(MI);
2337 bool isFrameSetup = MI.getFlag(MachineInstr::FrameSetup);
2338
2339 if (!isFrameSetup && MI.getDebugLoc()) {
2340 // Scan forward to try to find a non-zero line number. The
2341 // prologue_end marks the first breakpoint in the function after the
2342 // frame setup, and a compiler-generated line 0 location is not a
2343 // meaningful breakpoint. If none is found, return the first
2344 // location after the frame setup.
2345 if (MI.getDebugLoc().getLine())
2346 return std::make_pair(&MI, IsEmptyPrologue);
2347 }
2348
2349 // Keep track of the first "non-trivial" instruction seen, i.e. anything
2350 // that doesn't involve shuffling data around or is a frame-setup.
2351 if (!isCopy && !isTrivRemat && !isFrameSetup && !NonTrivialInst)
2352 NonTrivialInst = &MI;
2353
2354 IsEmptyPrologue = false;
2355 return std::nullopt;
2356 };
2357
2358 // Examine all the instructions at the start of the function. This doesn't
2359 // necessarily mean just the entry block: unoptimised code can fall-through
2360 // into an initial loop, and it makes sense to put the initial breakpoint on
2361 // the first instruction of such a loop. However, if we pass branches, we're
2362 // better off synthesising an early prologue_end.
2363 auto CurBlock = MF->begin();
2364 auto CurInst = CurBlock->begin();
2365
2366 // Find the initial instruction, we're guaranteed one by the caller, but not
2367 // which block it's in.
2368 while (CurBlock->empty())
2369 CurInst = (++CurBlock)->begin();
2370 assert(CurInst != CurBlock->end());
2371
2372 // Helper function for stepping through the initial sequence of
2373 // unconditionally executed instructions.
2374 auto getNextInst = [&CurBlock, &CurInst, MF]() -> bool {
2375 // We've reached the end of the block. Did we just look at a terminator?
2376 if (CurInst->isTerminator()) {
2377 // Some kind of "real" control flow is occurring. At the very least
2378 // we would have to start exploring the CFG, a good signal that the
2379 // prologue is over.
2380 return false;
2381 }
2382
2383 // If we've already fallen through into a loop, don't fall through
2384 // further, use a backup-location.
2385 if (CurBlock->pred_size() > 1)
2386 return false;
2387
2388 // Fall-through from entry to the next block. This is common at -O0 when
2389 // there's no initialisation in the function. Bail if we're also at the
2390 // end of the function, or the remaining blocks have no instructions.
2391 // Skip empty blocks, in rare cases the entry can be empty, and
2392 // other optimisations may add empty blocks that the control flow falls
2393 // through.
2394 do {
2395 ++CurBlock;
2396 if (CurBlock == MF->end())
2397 return false;
2398 } while (CurBlock->empty());
2399 CurInst = CurBlock->begin();
2400 return true;
2401 };
2402
2403 while (true) {
2404 // Check whether this non-meta instruction a good position for prologue_end.
2405 if (!CurInst->isMetaInstruction()) {
2406 auto FoundInst = ExamineInst(*CurInst);
2407 if (FoundInst)
2408 return *FoundInst;
2409 }
2410
2411 // In very rare scenarios function calls can have line zero, and we
2412 // shouldn't step over such a call while trying to reach prologue_end. In
2413 // these extraordinary conditions, force the call to have the scope line
2414 // and put prologue_end there. This isn't ideal, but signals that the call
2415 // is where execution in the function starts, and is less catastrophic than
2416 // stepping over the call.
2417 if (CurInst->isCall()) {
2418 if (const DILocation *Loc = CurInst->getDebugLoc().get();
2419 Loc && Loc->getLine() == 0) {
2420 // Create and assign the scope-line position.
2421 unsigned ScopeLine = SP->getScopeLine();
2422 DILocation *ScopeLineDILoc =
2423 DILocation::get(SP->getContext(), ScopeLine, 0, SP);
2424 const_cast<MachineInstr *>(&*CurInst)->setDebugLoc(ScopeLineDILoc);
2425
2426 // Consider this position to be where prologue_end is placed.
2427 return std::make_pair(&*CurInst, false);
2428 }
2429 }
2430
2431 // Try to continue searching, but use a backup-location if substantive
2432 // computation is happening.
2433 auto NextInst = std::next(CurInst);
2434 if (NextInst != CurInst->getParent()->end()) {
2435 // Continue examining the current block.
2436 CurInst = NextInst;
2437 continue;
2438 }
2439
2440 if (!getNextInst())
2441 break;
2442 }
2443
2444 // We couldn't find any source-location, suggesting all meaningful information
2445 // got optimised away. Set the prologue_end to be the first non-trivial
2446 // instruction, which will get the scope line number. This is better than
2447 // nothing.
2448 // Only do this in the entry block, as we'll be giving it the scope line for
2449 // the function. Return IsEmptyPrologue==true if we've picked the first
2450 // instruction.
2451 if (NonTrivialInst && NonTrivialInst->getParent() == &*MF->begin()) {
2452 IsEmptyPrologue = NonTrivialInst == &*MF->begin()->begin();
2453 return std::make_pair(NonTrivialInst, IsEmptyPrologue);
2454 }
2455
2456 // If the entry path is empty, just don't have a prologue_end at all.
2457 return std::make_pair(nullptr, IsEmptyPrologue);
2458}
2459
2460/// Register a source line with debug info. Returns the unique label that was
2461/// emitted and which provides correspondence to the source line list.
2462static void recordSourceLine(AsmPrinter &Asm, unsigned Line, unsigned Col,
2463 const MDNode *S, unsigned Flags, unsigned CUID,
2464 uint16_t DwarfVersion,
2465 ArrayRef<std::unique_ptr<DwarfCompileUnit>> DCUs,
2466 StringRef Comment = {}) {
2467 StringRef Fn;
2468 unsigned FileNo = 1;
2469 unsigned Discriminator = 0;
2470 if (auto *Scope = cast_or_null<DIScope>(S)) {
2471 Fn = Scope->getFilename();
2472 if (Line != 0 && DwarfVersion >= 4)
2473 if (auto *LBF = dyn_cast<DILexicalBlockFile>(Scope))
2474 Discriminator = LBF->getDiscriminator();
2475
2476 FileNo = static_cast<DwarfCompileUnit &>(*DCUs[CUID])
2477 .getOrCreateSourceID(Scope->getFile());
2478 }
2479 Asm.OutStreamer->emitDwarfLocDirective(FileNo, Line, Col, Flags, 0,
2480 Discriminator, Fn, Comment);
2481}
2482
2483const MachineInstr *
2485 // Don't deal with functions that have no instructions.
2486 if (llvm::all_of(MF, [](const MachineBasicBlock &MBB) { return MBB.empty(); }))
2487 return nullptr;
2488
2489 std::pair<const MachineInstr *, bool> PrologEnd = findPrologueEndLoc(&MF);
2490 const MachineInstr *PrologEndLoc = PrologEnd.first;
2491 bool IsEmptyPrologue = PrologEnd.second;
2492
2493 // If the prolog is empty, no need to generate scope line for the proc.
2494 if (IsEmptyPrologue) {
2495 // If there's nowhere to put a prologue_end flag, emit a scope line in case
2496 // there are simply no source locations anywhere in the function.
2497 if (PrologEndLoc) {
2498 // Avoid trying to assign prologue_end to a line-zero location.
2499 // Instructions with no DebugLoc at all are fine, they'll be given the
2500 // scope line nuumber.
2501 const DebugLoc &DL = PrologEndLoc->getDebugLoc();
2502 if (!DL || DL->getLine() != 0)
2503 return PrologEndLoc;
2504
2505 // Later, don't place the prologue_end flag on this line-zero location.
2506 PrologEndLoc = nullptr;
2507 }
2508 }
2509
2510 // Ensure the compile unit is created if the function is called before
2511 // beginFunction().
2513 (void)getOrCreateDwarfCompileUnit(SP->getUnit());
2514 // We'd like to list the prologue as "not statements" but GDB behaves
2515 // poorly if we do that. Revisit this with caution/GDB (7.5+) testing.
2516 ::recordSourceLine(*Asm, SP->getScopeLine(), 0, SP, DWARF2_FLAG_IS_STMT,
2517 CUID, getDwarfVersion(), getUnits());
2518 return PrologEndLoc;
2519}
2520
2521void DwarfDebug::computeKeyInstructions(const MachineFunction *MF) {
2522 // New function - reset KeyInstructions.
2523 KeyInstructions.clear();
2524
2525 // The current candidate is_stmt instructions for each source atom.
2526 // Map {(InlinedAt, Group): (Rank, Instructions)}.
2527 // NOTE: Anecdotally, for a large C++ blob, 99% of the instruction
2528 // SmallVectors contain 2 or fewer elements; use 2 inline elements.
2530 std::pair<uint8_t, SmallVector<const MachineInstr *, 2>>>
2531 GroupCandidates;
2532
2533 const auto &TII = *MF->getSubtarget().getInstrInfo();
2534
2535 // For each instruction:
2536 // * Skip insts without DebugLoc, AtomGroup or AtomRank, and line zeros.
2537 // * Check if insts in this group have been seen already in GroupCandidates.
2538 // * If this instr rank is equal, add this instruction to GroupCandidates.
2539 // Remove existing instructions from GroupCandidates if they have the
2540 // same parent.
2541 // * If this instr rank is higher (lower precedence), ignore it.
2542 // * If this instr rank is lower (higher precedence), erase existing
2543 // instructions from GroupCandidates and add this one.
2544 //
2545 // Then insert each GroupCandidates instruction into KeyInstructions.
2546
2547 for (auto &MBB : *MF) {
2548 // Rather than apply is_stmt directly to Key Instructions, we "float"
2549 // is_stmt up to the 1st instruction with the same line number in a
2550 // contiguous block. That instruction is called the "buoy". The
2551 // buoy gets reset if we encouner an instruction with an atom
2552 // group.
2553 const MachineInstr *Buoy = nullptr;
2554 // The atom group number associated with Buoy which may be 0 if we haven't
2555 // encountered an atom group yet in this blob of instructions with the same
2556 // line number.
2557 uint64_t BuoyAtom = 0;
2558
2559 for (auto &MI : MBB) {
2560 if (MI.isMetaInstruction())
2561 continue;
2562
2563 const DILocation *Loc = MI.getDebugLoc().get();
2564 if (!Loc || !Loc->getLine())
2565 continue;
2566
2567 // Reset the Buoy to this instruction if it has a different line number.
2568 if (!Buoy || Buoy->getDebugLoc().getLine() != Loc->getLine()) {
2569 Buoy = &MI;
2570 BuoyAtom = 0; // Set later when we know which atom the buoy is used by.
2571 }
2572
2573 // Call instructions are handled specially - we always mark them as key
2574 // regardless of atom info.
2575 bool IsCallLike = MI.isCall() || TII.isTailCall(MI);
2576 if (IsCallLike) {
2577 // Calls are always key. Put the buoy (may not be the call) into
2578 // KeyInstructions directly rather than the candidate map to avoid it
2579 // being erased (and we may not have a group number for the call).
2580 KeyInstructions.insert(Buoy);
2581
2582 // Avoid floating any future is_stmts up to the call.
2583 Buoy = nullptr;
2584 BuoyAtom = 0;
2585
2586 if (!Loc->getAtomGroup() || !Loc->getAtomRank())
2587 continue;
2588 }
2589
2590 auto *InlinedAt = Loc->getInlinedAt();
2591 uint64_t Group = Loc->getAtomGroup();
2592 uint8_t Rank = Loc->getAtomRank();
2593 if (!Group || !Rank)
2594 continue;
2595
2596 // Don't let is_stmts float past instructions from different source atoms.
2597 if (BuoyAtom && BuoyAtom != Group) {
2598 Buoy = &MI;
2599 BuoyAtom = Group;
2600 }
2601
2602 auto &[CandidateRank, CandidateInsts] =
2603 GroupCandidates[{InlinedAt, Group}];
2604
2605 // If CandidateRank is zero then CandidateInsts should be empty: there
2606 // are no other candidates for this group yet. If CandidateRank is nonzero
2607 // then CandidateInsts shouldn't be empty: we've got existing candidate
2608 // instructions.
2609 assert((CandidateRank == 0 && CandidateInsts.empty()) ||
2610 (CandidateRank != 0 && !CandidateInsts.empty()));
2611
2612 assert(Rank && "expected nonzero rank");
2613 // If we've seen other instructions in this group with higher precedence
2614 // (lower nonzero rank), don't add this one as a candidate.
2615 if (CandidateRank && CandidateRank < Rank)
2616 continue;
2617
2618 // If we've seen other instructions in this group of the same rank,
2619 // discard any from this block (keeping the others). Else if we've
2620 // seen other instructions in this group of lower precedence (higher
2621 // rank), discard them all.
2622 if (CandidateRank == Rank)
2623 llvm::remove_if(CandidateInsts, [&MI](const MachineInstr *Candidate) {
2624 return MI.getParent() == Candidate->getParent();
2625 });
2626 else if (CandidateRank > Rank)
2627 CandidateInsts.clear();
2628
2629 if (Buoy) {
2630 // Add this candidate.
2631 CandidateInsts.push_back(Buoy);
2632 CandidateRank = Rank;
2633
2634 assert(!BuoyAtom || BuoyAtom == Loc->getAtomGroup());
2635 BuoyAtom = Loc->getAtomGroup();
2636 } else {
2637 // Don't add calls, because they've been dealt with already. This means
2638 // CandidateInsts might now be empty - handle that.
2639 assert(IsCallLike);
2640 if (CandidateInsts.empty())
2641 CandidateRank = 0;
2642 }
2643 }
2644 }
2645
2646 for (const auto &[_, Insts] : GroupCandidates.values())
2647 for (auto *I : Insts)
2648 KeyInstructions.insert(I);
2649}
2650
2651/// For the function \p MF, finds the set of instructions which may represent a
2652/// change in line number from one or more of the preceding MBBs. Stores the
2653/// resulting set of instructions, which should have is_stmt set, in
2654/// ForceIsStmtInstrs.
2655void DwarfDebug::findForceIsStmtInstrs(const MachineFunction *MF) {
2656 ForceIsStmtInstrs.clear();
2657
2658 // For this function, we try to find MBBs where the last source line in every
2659 // block predecessor matches the first line seen in the block itself; for
2660 // every such MBB, we set is_stmt=false on the first line in the block, and
2661 // for every other block we set is_stmt=true on the first line.
2662 // For example, if we have the block %bb.3, which has 2 predecesors %bb.1 and
2663 // %bb.2:
2664 // bb.1:
2665 // $r3 = MOV64ri 12, debug-location !DILocation(line: 4)
2666 // JMP %bb.3, debug-location !DILocation(line: 5)
2667 // bb.2:
2668 // $r3 = MOV64ri 24, debug-location !DILocation(line: 5)
2669 // JMP %bb.3
2670 // bb.3:
2671 // $r2 = MOV64ri 1
2672 // $r1 = ADD $r2, $r3, debug-location !DILocation(line: 5)
2673 // When we examine %bb.3, we first check to see if it contains any
2674 // instructions with debug locations, and select the first such instruction;
2675 // in this case, the ADD, with line=5. We then examine both of its
2676 // predecessors to see what the last debug-location in them is. For each
2677 // predecessor, if they do not contain any debug-locations, or if the last
2678 // debug-location before jumping to %bb.3 does not have line=5, then the ADD
2679 // in %bb.3 must use IsStmt. In this case, all predecessors have a
2680 // debug-location with line=5 as the last debug-location before jumping to
2681 // %bb.3, so we do not set is_stmt for the ADD instruction - we know that
2682 // whichever MBB we have arrived from, the line has not changed.
2683
2684 const auto *TII = MF->getSubtarget().getInstrInfo();
2685
2686 // We only need to the predecessors of MBBs that could have is_stmt set by
2687 // this logic.
2688 SmallDenseSet<MachineBasicBlock *, 4> PredMBBsToExamine;
2689 SmallDenseMap<MachineBasicBlock *, MachineInstr *> PotentialIsStmtMBBInstrs;
2690 // We use const_cast even though we won't actually modify MF, because some
2691 // methods we need take a non-const MBB.
2692 for (auto &MBB : *const_cast<MachineFunction *>(MF)) {
2693 if (MBB.empty() || MBB.pred_empty())
2694 continue;
2695 for (auto &MI : MBB) {
2696 if (MI.getDebugLoc() && MI.getDebugLoc()->getLine()) {
2697 PredMBBsToExamine.insert_range(MBB.predecessors());
2698 PotentialIsStmtMBBInstrs.insert({&MBB, &MI});
2699 break;
2700 }
2701 }
2702 }
2703
2704 // For each predecessor MBB, we examine the last line seen before each branch
2705 // or logical fallthrough. We use analyzeBranch to handle cases where
2706 // different branches have different outgoing lines (i.e. if there are
2707 // multiple branches that each have their own source location); otherwise we
2708 // just use the last line in the block.
2709 for (auto *MBB : PredMBBsToExamine) {
2710 auto CheckMBBEdge = [&](MachineBasicBlock *Succ, unsigned OutgoingLine) {
2711 auto MBBInstrIt = PotentialIsStmtMBBInstrs.find(Succ);
2712 if (MBBInstrIt == PotentialIsStmtMBBInstrs.end())
2713 return;
2714 MachineInstr *MI = MBBInstrIt->second;
2715 if (MI->getDebugLoc()->getLine() == OutgoingLine)
2716 return;
2717 PotentialIsStmtMBBInstrs.erase(MBBInstrIt);
2718 ForceIsStmtInstrs.insert(MI);
2719 };
2720 // If this block is empty, we conservatively assume that its fallthrough
2721 // successor needs is_stmt; we could check MBB's predecessors to see if it
2722 // has a consistent entry line, but this seems unlikely to be worthwhile.
2723 if (MBB->empty()) {
2724 for (auto *Succ : MBB->successors())
2725 CheckMBBEdge(Succ, 0);
2726 continue;
2727 }
2728 // If MBB has no successors that are in the "potential" set, due to one or
2729 // more of them having confirmed is_stmt, we can skip this check early.
2730 if (none_of(MBB->successors(), [&](auto *SuccMBB) {
2731 return PotentialIsStmtMBBInstrs.contains(SuccMBB);
2732 }))
2733 continue;
2734 // If we can't determine what DLs this branch's successors use, just treat
2735 // all the successors as coming from the last DebugLoc.
2737 auto MIIt = MBB->rbegin();
2738 {
2739 MachineBasicBlock *TBB = nullptr, *FBB = nullptr;
2741 bool AnalyzeFailed = TII->analyzeBranch(*MBB, TBB, FBB, Cond);
2742 // For a conditional branch followed by unconditional branch where the
2743 // unconditional branch has a DebugLoc, that loc is the outgoing loc to
2744 // the the false destination only; otherwise, both destinations share an
2745 // outgoing loc.
2746 if (!AnalyzeFailed && !Cond.empty() && FBB != nullptr &&
2747 MBB->back().getDebugLoc() && MBB->back().getDebugLoc()->getLine()) {
2748 unsigned FBBLine = MBB->back().getDebugLoc()->getLine();
2749 assert(MIIt->isBranch() && "Bad result from analyzeBranch?");
2750 CheckMBBEdge(FBB, FBBLine);
2751 ++MIIt;
2752 SuccessorBBs.push_back(TBB);
2753 } else {
2754 // For all other cases, all successors share the last outgoing DebugLoc.
2755 SuccessorBBs.assign(MBB->succ_begin(), MBB->succ_end());
2756 }
2757 }
2758
2759 // If we don't find an outgoing loc, this block will start with a line 0.
2760 // It is possible that we have a block that has no DebugLoc, but acts as a
2761 // simple passthrough between two blocks that end and start with the same
2762 // line, e.g.:
2763 // bb.1:
2764 // JMP %bb.2, debug-location !10
2765 // bb.2:
2766 // JMP %bb.3
2767 // bb.3:
2768 // $r1 = ADD $r2, $r3, debug-location !10
2769 // If these blocks were merged into a single block, we would not attach
2770 // is_stmt to the ADD, but with this logic that only checks the immediate
2771 // predecessor, we will; we make this tradeoff because doing a full dataflow
2772 // analysis would be expensive, and these situations are probably not common
2773 // enough for this to be worthwhile.
2774 unsigned LastLine = 0;
2775 while (MIIt != MBB->rend()) {
2776 if (auto DL = MIIt->getDebugLoc(); DL && DL->getLine()) {
2777 LastLine = DL->getLine();
2778 break;
2779 }
2780 ++MIIt;
2781 }
2782 for (auto *Succ : SuccessorBBs)
2783 CheckMBBEdge(Succ, LastLine);
2784 }
2785}
2786
2787// Gather pre-function debug information. Assumes being called immediately
2788// after the function entry point has been emitted.
2790 CurFn = MF;
2791
2792 auto *SP = MF->getFunction().getSubprogram();
2793 assert(LScopes.empty() || SP == LScopes.getCurrentFunctionScope()->getScopeNode());
2794 if (SP->getUnit()->getEmissionKind() == DICompileUnit::NoDebug)
2795 return;
2796
2797 DwarfCompileUnit &CU = getOrCreateDwarfCompileUnit(SP->getUnit());
2798 FunctionLineTableLabel = CU.emitFuncLineTableOffsets()
2799 ? Asm->OutStreamer->emitLineTableLabel()
2800 : nullptr;
2801
2802 Asm->OutStreamer->getContext().setDwarfCompileUnitID(
2804
2805 // Call target-specific debug info initialization.
2807
2808 // Record beginning of function.
2810 *MF, Asm->OutStreamer->getContext().getDwarfCompileUnitID());
2811
2812 // Run both `findForceIsStmtInstrs` and `computeKeyInstructions` because
2813 // Not-Key-Instructions functions may be inlined into Key Instructions
2814 // functions and vice versa.
2816 computeKeyInstructions(MF);
2817 findForceIsStmtInstrs(MF);
2818}
2819
2820unsigned
2822 // Set DwarfDwarfCompileUnitID in MCContext to the Compile Unit this function
2823 // belongs to so that we add to the correct per-cu line table in the
2824 // non-asm case.
2825 if (Asm->OutStreamer->hasRawTextSupport())
2826 // Use a single line table if we are generating assembly.
2827 return 0;
2828 else
2829 return CU.getUniqueID();
2830}
2831
2833 const auto &CURanges = CU->getRanges();
2834 auto &LineTable = Asm->OutStreamer->getContext().getMCDwarfLineTable(
2836 // Add the last range label for the given CU.
2837 LineTable.getMCLineSections().addEndEntry(
2838 const_cast<MCSymbol *>(CURanges.back().End));
2839}
2840
2842 // If we don't have a subprogram for this function then there will be a hole
2843 // in the range information. Keep note of this by setting the previously used
2844 // section to nullptr.
2845 // Terminate the pending line table.
2846 if (PrevCU)
2847 terminateLineTable(PrevCU);
2848 PrevCU = nullptr;
2849 CurFn = nullptr;
2850}
2851
2852// Gather and emit post-function debug information.
2854 const Function &F = MF->getFunction();
2855 const DISubprogram *SP = F.getSubprogram();
2856
2857 assert(CurFn == MF &&
2858 "endFunction should be called with the same function as beginFunction");
2859
2860 // Set DwarfDwarfCompileUnitID in MCContext to default value.
2861 Asm->OutStreamer->getContext().setDwarfCompileUnitID(0);
2862
2863 LexicalScope *FnScope = LScopes.getCurrentFunctionScope();
2864 assert(!FnScope || SP == FnScope->getScopeNode());
2865 DwarfCompileUnit &TheCU = getOrCreateDwarfCompileUnit(SP->getUnit());
2866 if (TheCU.getCUNode()->isDebugDirectivesOnly()) {
2867 PrevLabel = nullptr;
2868 CurFn = nullptr;
2869 return;
2870 }
2871
2872 DenseSet<InlinedEntity> Processed;
2873 collectEntityInfo(TheCU, SP, Processed);
2874
2875 // Add the range of this function to the list of ranges for the CU.
2876 // With basic block sections, add ranges for all basic block sections.
2877 for (const auto &R : Asm->MBBSectionRanges)
2878 TheCU.addRange({R.second.BeginLabel, R.second.EndLabel});
2879
2880 // Under -gmlt, skip building the subprogram if there are no inlined
2881 // subroutines inside it. But with -fdebug-info-for-profiling, the subprogram
2882 // is still needed as we need its source location.
2883 if (!TheCU.getCUNode()->getDebugInfoForProfiling() &&
2885 LScopes.getAbstractScopesList().empty() && !IsDarwin) {
2886 for (const auto &R : Asm->MBBSectionRanges)
2887 addArangeLabel(SymbolCU(&TheCU, R.second.BeginLabel));
2888
2889 assert(InfoHolder.getScopeVariables().empty());
2890 PrevLabel = nullptr;
2891 CurFn = nullptr;
2892 return;
2893 }
2894
2895#ifndef NDEBUG
2896 size_t NumAbstractSubprograms = LScopes.getAbstractScopesList().size();
2897#endif
2898 for (LexicalScope *AScope : LScopes.getAbstractScopesList()) {
2899 const auto *SP = cast<DISubprogram>(AScope->getScopeNode());
2900 for (const DINode *DN : SP->getRetainedNodes()) {
2901 const auto *LS = getRetainedNodeScope(DN);
2902 // Ensure LexicalScope is created for the scope of this node.
2903 auto *LexS = LScopes.getOrCreateAbstractScope(LS);
2904 assert(LexS && "Expected the LexicalScope to be created.");
2905 if (isa<DILocalVariable>(DN) || isa<DILabel>(DN)) {
2906 // Collect info for variables/labels that were optimized out.
2907 if (!Processed.insert(InlinedEntity(DN, nullptr)).second ||
2908 TheCU.getExistingAbstractEntity(DN))
2909 continue;
2910 TheCU.createAbstractEntity(DN, LexS);
2911 } else {
2912 // Remember the node if this is a local declarations.
2913 LocalDeclsPerLS[LS].insert(DN);
2914 }
2915 assert(
2916 LScopes.getAbstractScopesList().size() == NumAbstractSubprograms &&
2917 "getOrCreateAbstractScope() inserted an abstract subprogram scope");
2918 }
2919 constructAbstractSubprogramScopeDIE(TheCU, AScope);
2920 }
2921
2922 ProcessedSPNodes.insert(SP);
2923 DIE &ScopeDIE =
2924 TheCU.constructSubprogramScopeDIE(SP, F, FnScope, FunctionLineTableLabel);
2925 if (auto *SkelCU = TheCU.getSkeleton())
2926 if (!LScopes.getAbstractScopesList().empty() &&
2928 SkelCU->constructSubprogramScopeDIE(SP, F, FnScope,
2929 FunctionLineTableLabel);
2930
2931 FunctionLineTableLabel = nullptr;
2932
2933 // Construct call site entries.
2934 constructCallSiteEntryDIEs(*SP, TheCU, ScopeDIE, *MF);
2935
2936 // Clear debug info
2937 // Ownership of DbgVariables is a bit subtle - ScopeVariables owns all the
2938 // DbgVariables except those that are also in AbstractVariables (since they
2939 // can be used cross-function)
2940 InfoHolder.getScopeVariables().clear();
2941 InfoHolder.getScopeLabels().clear();
2942 LocalDeclsPerLS.clear();
2943 PrevLabel = nullptr;
2944 CurFn = nullptr;
2945}
2946
2947// Register a source line with debug info. Returns the unique label that was
2948// emitted and which provides correspondence to the source line list.
2949void DwarfDebug::recordSourceLine(unsigned Line, unsigned Col, const MDNode *S,
2950 unsigned Flags, StringRef Location) {
2951 ::recordSourceLine(*Asm, Line, Col, S, Flags,
2952 Asm->OutStreamer->getContext().getDwarfCompileUnitID(),
2953 getDwarfVersion(), getUnits(), Location);
2954}
2955
2956//===----------------------------------------------------------------------===//
2957// Emit Methods
2958//===----------------------------------------------------------------------===//
2959
2960// Emit the debug info section.
2961void DwarfDebug::emitDebugInfo() {
2962 DwarfFile &Holder = useSplitDwarf() ? SkeletonHolder : InfoHolder;
2963 Holder.emitUnits(/* UseOffsets */ false);
2964}
2965
2966// Emit the abbreviation section.
2967void DwarfDebug::emitAbbreviations() {
2968 DwarfFile &Holder = useSplitDwarf() ? SkeletonHolder : InfoHolder;
2969
2970 Holder.emitAbbrevs(Asm->getObjFileLowering().getDwarfAbbrevSection());
2971}
2972
2973void DwarfDebug::emitStringOffsetsTableHeader() {
2974 DwarfFile &Holder = useSplitDwarf() ? SkeletonHolder : InfoHolder;
2976 *Asm, Asm->getObjFileLowering().getDwarfStrOffSection(),
2977 Holder.getStringOffsetsStartSym());
2978}
2979
2980template <typename AccelTableT>
2981void DwarfDebug::emitAccel(AccelTableT &Accel, MCSection *Section,
2982 StringRef TableName) {
2983 Asm->OutStreamer->switchSection(Section);
2984
2985 // Emit the full data.
2986 emitAppleAccelTable(Asm, Accel, TableName, Section->getBeginSymbol());
2987}
2988
2989void DwarfDebug::emitAccelDebugNames() {
2990 // Don't emit anything if we have no compilation units to index.
2991 if (getUnits().empty())
2992 return;
2993
2994 emitDWARF5AccelTable(Asm, AccelDebugNames, *this, getUnits());
2995}
2996
2997// Emit visible names into a hashed accelerator table section.
2998void DwarfDebug::emitAccelNames() {
2999 emitAccel(AccelNames, Asm->getObjFileLowering().getDwarfAccelNamesSection(),
3000 "Names");
3001}
3002
3003// Emit objective C classes and categories into a hashed accelerator table
3004// section.
3005void DwarfDebug::emitAccelObjC() {
3006 emitAccel(AccelObjC, Asm->getObjFileLowering().getDwarfAccelObjCSection(),
3007 "ObjC");
3008}
3009
3010// Emit namespace dies into a hashed accelerator table.
3011void DwarfDebug::emitAccelNamespaces() {
3012 emitAccel(AccelNamespace,
3013 Asm->getObjFileLowering().getDwarfAccelNamespaceSection(),
3014 "namespac");
3015}
3016
3017// Emit type dies into a hashed accelerator table.
3018void DwarfDebug::emitAccelTypes() {
3019 emitAccel(AccelTypes, Asm->getObjFileLowering().getDwarfAccelTypesSection(),
3020 "types");
3021}
3022
3023// Public name handling.
3024// The format for the various pubnames:
3025//
3026// dwarf pubnames - offset/name pairs where the offset is the offset into the CU
3027// for the DIE that is named.
3028//
3029// gnu pubnames - offset/index value/name tuples where the offset is the offset
3030// into the CU and the index value is computed according to the type of value
3031// for the DIE that is named.
3032//
3033// For type units the offset is the offset of the skeleton DIE. For split dwarf
3034// it's the offset within the debug_info/debug_types dwo section, however, the
3035// reference in the pubname header doesn't change.
3036
3037/// computeIndexValue - Compute the gdb index value for the DIE and CU.
3039 const DIE *Die) {
3040 // Entities that ended up only in a Type Unit reference the CU instead (since
3041 // the pub entry has offsets within the CU there's no real offset that can be
3042 // provided anyway). As it happens all such entities (namespaces and types,
3043 // types only in C++ at that) are rendered as TYPE+EXTERNAL. If this turns out
3044 // not to be true it would be necessary to persist this information from the
3045 // point at which the entry is added to the index data structure - since by
3046 // the time the index is built from that, the original type/namespace DIE in a
3047 // type unit has already been destroyed so it can't be queried for properties
3048 // like tag, etc.
3049 if (Die->getTag() == dwarf::DW_TAG_compile_unit)
3053
3054 // We could have a specification DIE that has our most of our knowledge,
3055 // look for that now.
3056 if (DIEValue SpecVal = Die->findAttribute(dwarf::DW_AT_specification)) {
3057 DIE &SpecDIE = SpecVal.getDIEEntry().getEntry();
3058 if (SpecDIE.findAttribute(dwarf::DW_AT_external))
3060 } else if (Die->findAttribute(dwarf::DW_AT_external))
3062
3063 switch (Die->getTag()) {
3064 case dwarf::DW_TAG_class_type:
3065 case dwarf::DW_TAG_structure_type:
3066 case dwarf::DW_TAG_union_type:
3067 case dwarf::DW_TAG_enumeration_type:
3069 dwarf::GIEK_TYPE, dwarf::isCPlusPlus(CU->getSourceLanguage())
3072 case dwarf::DW_TAG_typedef:
3073 case dwarf::DW_TAG_base_type:
3074 case dwarf::DW_TAG_subrange_type:
3075 case dwarf::DW_TAG_template_alias:
3077 case dwarf::DW_TAG_namespace:
3078 return dwarf::GIEK_TYPE;
3079 case dwarf::DW_TAG_subprogram:
3081 case dwarf::DW_TAG_variable:
3083 case dwarf::DW_TAG_enumerator:
3086 default:
3087 return dwarf::GIEK_NONE;
3088 }
3089}
3090
3091/// emitDebugPubSections - Emit visible names and types into debug pubnames and
3092/// pubtypes sections.
3093void DwarfDebug::emitDebugPubSections() {
3094 for (const auto &NU : CUMap) {
3095 DwarfCompileUnit *TheU = NU.second;
3096 if (!TheU->hasDwarfPubSections())
3097 continue;
3098
3099 bool GnuStyle = TheU->getCUNode()->getNameTableKind() ==
3101
3102 Asm->OutStreamer->switchSection(
3103 GnuStyle ? Asm->getObjFileLowering().getDwarfGnuPubNamesSection()
3104 : Asm->getObjFileLowering().getDwarfPubNamesSection());
3105 emitDebugPubSection(GnuStyle, "Names", TheU, TheU->getGlobalNames());
3106
3107 Asm->OutStreamer->switchSection(
3108 GnuStyle ? Asm->getObjFileLowering().getDwarfGnuPubTypesSection()
3109 : Asm->getObjFileLowering().getDwarfPubTypesSection());
3110 emitDebugPubSection(GnuStyle, "Types", TheU, TheU->getGlobalTypes());
3111 }
3112}
3113
3114void DwarfDebug::emitSectionReference(const DwarfCompileUnit &CU) {
3116 Asm->emitDwarfOffset(CU.getSection()->getBeginSymbol(),
3117 CU.getDebugSectionOffset());
3118 else
3119 Asm->emitDwarfSymbolReference(CU.getLabelBegin());
3120}
3121
3122void DwarfDebug::emitDebugPubSection(bool GnuStyle, StringRef Name,
3123 DwarfCompileUnit *TheU,
3124 const StringMap<const DIE *> &Globals) {
3125 if (auto *Skeleton = TheU->getSkeleton())
3126 TheU = Skeleton;
3127
3128 // Emit the header.
3129 MCSymbol *EndLabel = Asm->emitDwarfUnitLength(
3130 "pub" + Name, "Length of Public " + Name + " Info");
3131
3132 Asm->OutStreamer->AddComment("DWARF Version");
3133 Asm->emitInt16(dwarf::DW_PUBNAMES_VERSION);
3134
3135 Asm->OutStreamer->AddComment("Offset of Compilation Unit Info");
3136 emitSectionReference(*TheU);
3137
3138 Asm->OutStreamer->AddComment("Compilation Unit Length");
3139 Asm->emitDwarfLengthOrOffset(TheU->getLength());
3140
3141 // Emit the pubnames for this compilation unit.
3143 for (const auto &GI : Globals)
3144 Vec.emplace_back(GI.first(), GI.second);
3145 llvm::sort(Vec, [](auto &A, auto &B) {
3146 return A.second->getOffset() < B.second->getOffset();
3147 });
3148 for (const auto &[Name, Entity] : Vec) {
3149 Asm->OutStreamer->AddComment("DIE offset");
3150 Asm->emitDwarfLengthOrOffset(Entity->getOffset());
3151
3152 if (GnuStyle) {
3153 dwarf::PubIndexEntryDescriptor Desc = computeIndexValue(TheU, Entity);
3154 Asm->OutStreamer->AddComment(
3155 Twine("Attributes: ") + dwarf::GDBIndexEntryKindString(Desc.Kind) +
3156 ", " + dwarf::GDBIndexEntryLinkageString(Desc.Linkage));
3157 Asm->emitInt8(Desc.toBits());
3158 }
3159
3160 Asm->OutStreamer->AddComment("External Name");
3161 Asm->OutStreamer->emitBytes(StringRef(Name.data(), Name.size() + 1));
3162 }
3163
3164 Asm->OutStreamer->AddComment("End Mark");
3165 Asm->emitDwarfLengthOrOffset(0);
3166 Asm->OutStreamer->emitLabel(EndLabel);
3167}
3168
3169/// Emit null-terminated strings into a debug str section.
3170void DwarfDebug::emitDebugStr() {
3171 MCSection *StringOffsetsSection = nullptr;
3173 emitStringOffsetsTableHeader();
3174 StringOffsetsSection = Asm->getObjFileLowering().getDwarfStrOffSection();
3175 }
3176 DwarfFile &Holder = useSplitDwarf() ? SkeletonHolder : InfoHolder;
3177 Holder.emitStrings(Asm->getObjFileLowering().getDwarfStrSection(),
3178 StringOffsetsSection, /* UseRelativeOffsets = */ true);
3179}
3180
3182 const DebugLocStream::Entry &Entry,
3183 const DwarfCompileUnit *CU) {
3184 auto &&Comments = DebugLocs.getComments(Entry);
3185 auto Comment = Comments.begin();
3186 auto End = Comments.end();
3187
3188 // The expressions are inserted into a byte stream rather early (see
3189 // DwarfExpression::addExpression) so for those ops (e.g. DW_OP_convert) that
3190 // need to reference a base_type DIE the offset of that DIE is not yet known.
3191 // To deal with this we instead insert a placeholder early and then extract
3192 // it here and replace it with the real reference.
3193 unsigned PtrSize = Asm->MAI.getCodePointerSize();
3194 DWARFDataExtractor Data(StringRef(DebugLocs.getBytes(Entry).data(),
3195 DebugLocs.getBytes(Entry).size()),
3196 Asm->getDataLayout().isLittleEndian(), PtrSize);
3197 DWARFExpression Expr(Data, PtrSize, Asm->OutContext.getDwarfFormat());
3198
3199 using Encoding = DWARFExpression::Operation::Encoding;
3200 uint64_t Offset = 0;
3201 for (const auto &Op : Expr) {
3202 assert(Op.getCode() != dwarf::DW_OP_const_type &&
3203 "3 operand ops not yet supported");
3204 assert(!Op.getSubCode() && "SubOps not yet supported");
3205 Streamer.emitInt8(Op.getCode(), Comment != End ? *(Comment++) : "");
3206 Offset++;
3207 for (unsigned I = 0; I < Op.getDescription().Op.size(); ++I) {
3208 if (Op.getDescription().Op[I] == Encoding::BaseTypeRef) {
3209 unsigned Length =
3210 Streamer.emitDIERef(*CU->ExprRefedBaseTypes[Op.getRawOperand(I)].Die);
3211 // Make sure comments stay aligned.
3212 for (unsigned J = 0; J < Length; ++J)
3213 if (Comment != End)
3214 Comment++;
3215 } else {
3216 for (uint64_t J = Offset; J < Op.getOperandEndOffset(I); ++J)
3217 Streamer.emitInt8(Data.getData()[J], Comment != End ? *(Comment++) : "");
3218 }
3219 Offset = Op.getOperandEndOffset(I);
3220 }
3221 assert(Offset == Op.getEndOffset());
3222 }
3223}
3224
3226 const DbgValueLoc &Value,
3227 DwarfExpression &DwarfExpr) {
3228 auto *DIExpr = Value.getExpression();
3229 DIExpressionCursor ExprCursor(DIExpr);
3230 DwarfExpr.addFragmentOffset(DIExpr);
3231
3232 // If the DIExpr is an Entry Value, we want to follow the same code path
3233 // regardless of whether the DBG_VALUE is variadic or not.
3234 if (DIExpr && DIExpr->isEntryValue()) {
3235 // Entry values can only be a single register with no additional DIExpr,
3236 // so just add it directly.
3237 assert(Value.getLocEntries().size() == 1);
3238 assert(Value.getLocEntries()[0].isLocation());
3239 MachineLocation Location = Value.getLocEntries()[0].getLoc();
3240 DwarfExpr.setLocation(Location, DIExpr);
3241
3242 DwarfExpr.beginEntryValueExpression(ExprCursor);
3243
3245 if (!DwarfExpr.addMachineRegExpression(TRI, ExprCursor, Location.getReg()))
3246 return;
3247 return DwarfExpr.addExpression(std::move(ExprCursor));
3248 }
3249
3250 // Regular entry.
3251 auto EmitValueLocEntry = [&DwarfExpr, &BT,
3252 &AP](const DbgValueLocEntry &Entry,
3253 DIExpressionCursor &Cursor) -> bool {
3254 if (Entry.isInt()) {
3255 if (BT && (BT->getEncoding() == dwarf::DW_ATE_boolean)) {
3256 DwarfExpr.addBooleanConstant(Entry.getInt());
3257 return true;
3258 }
3259
3260 bool IsSigned = BT && (BT->getEncoding() == dwarf::DW_ATE_signed ||
3261 BT->getEncoding() == dwarf::DW_ATE_signed_char);
3262 if (BT && AP.getDwarfVersion() >= 4 &&
3263 !AP.getDwarfDebug()->tuneForSCE() && !Cursor) {
3264 // DW_OP_const* pushes a generic, address-sized value. For a wider
3265 // source integer value that cannot fit in the generic type, use
3266 // DW_OP_implicit_value to preserve the source bytes instead. Keep this
3267 // limited to complete constant values: SCE tuning already avoids
3268 // DW_OP_implicit_value for compatibility, and expressions with
3269 // remaining operations may need a scalar stack value rather than an
3270 // implicit value block.
3271 unsigned GenericBitSize = AP.MAI.getCodePointerSize() * 8;
3272 uint64_t TypeBitSize = BT->getSizeInBits();
3273 bool IsByteSized = TypeBitSize % 8 == 0;
3274 bool IsOutOfRange =
3275 IsSigned ? !isIntN(GenericBitSize, Entry.getInt())
3276 : !isUIntN(GenericBitSize,
3277 static_cast<uint64_t>(Entry.getInt()));
3278 if (TypeBitSize > GenericBitSize && IsByteSized && IsOutOfRange) {
3279 DwarfExpr.addImplicitValue(
3280 APInt(static_cast<unsigned>(TypeBitSize),
3281 static_cast<uint64_t>(Entry.getInt()), IsSigned,
3282 /*implicitTrunc=*/true),
3283 AP);
3284 return true;
3285 }
3286 }
3287
3288 if (IsSigned)
3289 DwarfExpr.addSignedConstant(Entry.getInt());
3290 else
3291 DwarfExpr.addUnsignedConstant(Entry.getInt());
3292 } else if (Entry.isLocation()) {
3293 MachineLocation Location = Entry.getLoc();
3294 if (Location.isIndirect())
3295 DwarfExpr.setMemoryLocationKind();
3296
3298 if (!DwarfExpr.addMachineRegExpression(TRI, Cursor, Location.getReg()))
3299 return false;
3300 } else if (Entry.isTargetIndexLocation()) {
3301 TargetIndexLocation Loc = Entry.getTargetIndexLocation();
3302 // TODO TargetIndexLocation is a target-independent. Currently only the
3303 // WebAssembly-specific encoding is supported.
3305 DwarfExpr.addWasmLocation(Loc.Index, static_cast<uint64_t>(Loc.Offset));
3306 } else if (Entry.isConstantFP()) {
3307 if (AP.getDwarfVersion() >= 4 && !AP.getDwarfDebug()->tuneForSCE() &&
3308 !Cursor) {
3309 DwarfExpr.addConstantFP(Entry.getConstantFP()->getValueAPF(), AP);
3310 } else if (Entry.getConstantFP()
3311 ->getValueAPF()
3312 .bitcastToAPInt()
3313 .getBitWidth() <= 64 /*bits*/) {
3314 DwarfExpr.addUnsignedConstant(
3315 Entry.getConstantFP()->getValueAPF().bitcastToAPInt());
3316 } else {
3317 LLVM_DEBUG(
3318 dbgs() << "Skipped DwarfExpression creation for ConstantFP of size"
3319 << Entry.getConstantFP()
3320 ->getValueAPF()
3321 .bitcastToAPInt()
3322 .getBitWidth()
3323 << " bits\n");
3324 return false;
3325 }
3326 }
3327 return true;
3328 };
3329
3330 if (!Value.isVariadic()) {
3331 if (!EmitValueLocEntry(Value.getLocEntries()[0], ExprCursor))
3332 return;
3333 DwarfExpr.addExpression(std::move(ExprCursor));
3334 return;
3335 }
3336
3337 // If any of the location entries are registers with the value 0, then the
3338 // location is undefined.
3339 if (any_of(Value.getLocEntries(), [](const DbgValueLocEntry &Entry) {
3340 return Entry.isLocation() && !Entry.getLoc().getReg();
3341 }))
3342 return;
3343
3344 DwarfExpr.addExpression(
3345 std::move(ExprCursor),
3346 [EmitValueLocEntry, &Value](unsigned Idx,
3347 DIExpressionCursor &Cursor) -> bool {
3348 return EmitValueLocEntry(Value.getLocEntries()[Idx], Cursor);
3349 });
3350}
3351
3354 const DIBasicType *BT,
3355 DwarfCompileUnit &TheCU) {
3356 assert(!Values.empty() &&
3357 "location list entries without values are redundant");
3358 assert(Begin != End && "unexpected location list entry with empty range");
3359 DebugLocStream::EntryBuilder Entry(List, Begin, End);
3360 BufferByteStreamer Streamer = Entry.getStreamer();
3361 DebugLocDwarfExpression DwarfExpr(AP.getDwarfVersion(), Streamer, TheCU);
3362 const DbgValueLoc &Value = Values[0];
3363 if (Value.isFragment()) {
3364 // Emit all fragments that belong to the same variable and range.
3365 assert(llvm::all_of(Values, [](DbgValueLoc P) {
3366 return P.isFragment();
3367 }) && "all values are expected to be fragments");
3368 assert(llvm::is_sorted(Values) && "fragments are expected to be sorted");
3369
3370 for (const auto &Fragment : Values)
3371 DwarfDebug::emitDebugLocValue(AP, BT, Fragment, DwarfExpr);
3372
3373 } else {
3374 assert(Values.size() == 1 && "only fragments may have >1 value");
3375 DwarfDebug::emitDebugLocValue(AP, BT, Value, DwarfExpr);
3376 }
3377 DwarfExpr.finalize();
3378 if (DwarfExpr.TagOffset)
3379 List.setTagOffset(*DwarfExpr.TagOffset);
3380}
3381
3383 const DwarfCompileUnit *CU) {
3384 // Emit the size.
3385 Asm->OutStreamer->AddComment("Loc expr size");
3386 if (getDwarfVersion() >= 5)
3387 Asm->emitULEB128(DebugLocs.getBytes(Entry).size());
3388 else if (DebugLocs.getBytes(Entry).size() <= std::numeric_limits<uint16_t>::max())
3389 Asm->emitInt16(DebugLocs.getBytes(Entry).size());
3390 else {
3391 // The entry is too big to fit into 16 bit, drop it as there is nothing we
3392 // can do.
3393 Asm->emitInt16(0);
3394 return;
3395 }
3396 // Emit the entry.
3397 APByteStreamer Streamer(*Asm);
3398 emitDebugLocEntry(Streamer, Entry, CU);
3399}
3400
3401// Emit the header of a DWARF 5 range list table list table. Returns the symbol
3402// that designates the end of the table for the caller to emit when the table is
3403// complete.
3405 const DwarfFile &Holder) {
3406 MCSymbol *TableEnd = mcdwarf::emitListsTableHeaderStart(*Asm->OutStreamer);
3407
3408 Asm->OutStreamer->AddComment("Offset entry count");
3409 Asm->emitInt32(Holder.getRangeLists().size());
3410 Asm->OutStreamer->emitLabel(Holder.getRnglistsTableBaseSym());
3411
3412 for (const RangeSpanList &List : Holder.getRangeLists())
3413 Asm->emitLabelDifference(List.Label, Holder.getRnglistsTableBaseSym(),
3414 Asm->getDwarfOffsetByteSize());
3415
3416 return TableEnd;
3417}
3418
3419// Emit the header of a DWARF 5 locations list table. Returns the symbol that
3420// designates the end of the table for the caller to emit when the table is
3421// complete.
3423 const DwarfDebug &DD) {
3424 MCSymbol *TableEnd = mcdwarf::emitListsTableHeaderStart(*Asm->OutStreamer);
3425
3426 const auto &DebugLocs = DD.getDebugLocs();
3427
3428 Asm->OutStreamer->AddComment("Offset entry count");
3429 Asm->emitInt32(DebugLocs.getLists().size());
3430 Asm->OutStreamer->emitLabel(DebugLocs.getSym());
3431
3432 for (const auto &List : DebugLocs.getLists())
3433 Asm->emitLabelDifference(List.Label, DebugLocs.getSym(),
3434 Asm->getDwarfOffsetByteSize());
3435
3436 return TableEnd;
3437}
3438
3439template <typename Ranges, typename PayloadEmitter>
3440static void
3441emitRangeList(DwarfDebug &DD, AsmPrinter *Asm, MCSymbol *Sym, const Ranges &R,
3442 const DwarfCompileUnit &CU, unsigned BaseAddressx,
3443 unsigned OffsetPair, unsigned StartxLength, unsigned StartxEndx,
3444 unsigned EndOfList, StringRef (*StringifyEnum)(unsigned),
3445 bool ShouldUseBaseAddress, PayloadEmitter EmitPayload) {
3446 auto Size = Asm->MAI.getCodePointerSize();
3447 bool UseDwarf5 = DD.getDwarfVersion() >= 5;
3448
3449 // Emit our symbol so we can find the beginning of the range.
3450 Asm->OutStreamer->emitLabel(Sym);
3451
3452 // Gather all the ranges that apply to the same section so they can share
3453 // a base address entry.
3454 SmallMapVector<const MCSection *, std::vector<decltype(&*R.begin())>, 16>
3455 SectionRanges;
3456
3457 for (const auto &Range : R)
3458 SectionRanges[&Range.Begin->getSection()].push_back(&Range);
3459
3460 const MCSymbol *CUBase = CU.getBaseAddress();
3461 bool BaseIsSet = false;
3462 for (const auto &P : SectionRanges) {
3463 auto *Base = CUBase;
3464 if (DD.shouldResetBaseAddress(*P.first) ||
3465 (DD.useSplitDwarf() && UseDwarf5 && P.first->isLinkerRelaxable())) {
3466 BaseIsSet = false;
3467 Base = nullptr;
3468 } else if (!Base && ShouldUseBaseAddress) {
3469 const MCSymbol *Begin = P.second.front()->Begin;
3470 const MCSymbol *NewBase = DD.getSectionLabel(&Begin->getSection());
3471 if (!UseDwarf5) {
3472 Base = NewBase;
3473 BaseIsSet = true;
3474 Asm->OutStreamer->emitIntValue(-1, Size);
3475 Asm->OutStreamer->AddComment(" base address");
3476 Asm->OutStreamer->emitSymbolValue(Base, Size);
3477 } else if (NewBase != Begin || P.second.size() > 1) {
3478 // Only use a base address if
3479 // * the existing pool address doesn't match (NewBase != Begin)
3480 // * or, there's more than one entry to share the base address
3481 Base = NewBase;
3482 BaseIsSet = true;
3483 Asm->OutStreamer->AddComment(StringifyEnum(BaseAddressx));
3484 Asm->emitInt8(BaseAddressx);
3485 Asm->OutStreamer->AddComment(" base address index");
3486 Asm->emitULEB128(DD.getAddressPool().getIndex(Base));
3487 }
3488 } else if (BaseIsSet && !UseDwarf5) {
3489 BaseIsSet = false;
3490 assert(!Base);
3491 Asm->OutStreamer->emitIntValue(-1, Size);
3492 Asm->OutStreamer->emitIntValue(0, Size);
3493 }
3494
3495 for (const auto *RS : P.second) {
3496 const MCSymbol *Begin = RS->Begin;
3497 const MCSymbol *End = RS->End;
3498 assert(Begin && "Range without a begin symbol?");
3499 assert(End && "Range without an end symbol?");
3500 if (Base) {
3501 if (UseDwarf5) {
3502 // Emit offset_pair when we have a base.
3503 Asm->OutStreamer->AddComment(StringifyEnum(OffsetPair));
3504 Asm->emitInt8(OffsetPair);
3505 Asm->OutStreamer->AddComment(" starting offset");
3506 Asm->emitLabelDifferenceAsULEB128(Begin, Base);
3507 Asm->OutStreamer->AddComment(" ending offset");
3508 Asm->emitLabelDifferenceAsULEB128(End, Base);
3509 } else {
3510 Asm->emitLabelDifference(Begin, Base, Size);
3511 Asm->emitLabelDifference(End, Base, Size);
3512 }
3513 } else if (UseDwarf5) {
3514 // NOTE: We can't use absoluteSymbolDiff here instead of
3515 // isRangeRelaxable. While isRangeRelaxable only checks that the offset
3516 // between labels won't change at link time (which is exactly what we
3517 // need), absoluteSymbolDiff also requires that the offset remain
3518 // unchanged at assembly time, imposing a much stricter condition.
3519 // Consequently, this would lead to less optimal debug info emission.
3520 if (DD.useSplitDwarf() && llvm::isRangeRelaxable(Begin, End)) {
3521 Asm->OutStreamer->AddComment(StringifyEnum(StartxEndx));
3522 Asm->emitInt8(StartxEndx);
3523 Asm->OutStreamer->AddComment(" start index");
3524 Asm->emitULEB128(DD.getAddressPool().getIndex(Begin));
3525 Asm->OutStreamer->AddComment(" end index");
3526 Asm->emitULEB128(DD.getAddressPool().getIndex(End));
3527 } else {
3528 Asm->OutStreamer->AddComment(StringifyEnum(StartxLength));
3529 Asm->emitInt8(StartxLength);
3530 Asm->OutStreamer->AddComment(" start index");
3531 Asm->emitULEB128(DD.getAddressPool().getIndex(Begin));
3532 Asm->OutStreamer->AddComment(" length");
3533 Asm->emitLabelDifferenceAsULEB128(End, Begin);
3534 }
3535 } else {
3536 Asm->OutStreamer->emitSymbolValue(Begin, Size);
3537 Asm->OutStreamer->emitSymbolValue(End, Size);
3538 }
3539 EmitPayload(*RS);
3540 }
3541 }
3542
3543 if (UseDwarf5) {
3544 Asm->OutStreamer->AddComment(StringifyEnum(EndOfList));
3545 Asm->emitInt8(EndOfList);
3546 } else {
3547 // Terminate the list with two 0 values.
3548 Asm->OutStreamer->emitIntValue(0, Size);
3549 Asm->OutStreamer->emitIntValue(0, Size);
3550 }
3551}
3552
3553// Handles emission of both debug_loclist / debug_loclist.dwo
3554static void emitLocList(DwarfDebug &DD, AsmPrinter *Asm, const DebugLocStream::List &List) {
3556 DD, Asm, List.Label, DD.getDebugLocs().getEntries(List), *List.CU,
3557 dwarf::DW_LLE_base_addressx, dwarf::DW_LLE_offset_pair,
3558 dwarf::DW_LLE_startx_length, dwarf::DW_LLE_startx_endx,
3559 dwarf::DW_LLE_end_of_list, llvm::dwarf::LocListEncodingString,
3560 /* ShouldUseBaseAddress */ true, [&](const DebugLocStream::Entry &E) {
3561 DD.emitDebugLocEntryLocation(E, List.CU);
3562 });
3563}
3564
3565void DwarfDebug::emitDebugLocImpl(MCSection *Sec) {
3566 if (DebugLocs.getLists().empty())
3567 return;
3568
3569 Asm->OutStreamer->switchSection(Sec);
3570
3571 MCSymbol *TableEnd = nullptr;
3572 if (getDwarfVersion() >= 5)
3573 TableEnd = emitLoclistsTableHeader(Asm, *this);
3574
3575 for (const auto &List : DebugLocs.getLists())
3576 emitLocList(*this, Asm, List);
3577
3578 if (TableEnd)
3579 Asm->OutStreamer->emitLabel(TableEnd);
3580}
3581
3582// Emit locations into the .debug_loc/.debug_loclists section.
3583void DwarfDebug::emitDebugLoc() {
3584 emitDebugLocImpl(
3585 getDwarfVersion() >= 5
3586 ? Asm->getObjFileLowering().getDwarfLoclistsSection()
3587 : Asm->getObjFileLowering().getDwarfLocSection());
3588}
3589
3590// Emit locations into the .debug_loc.dwo/.debug_loclists.dwo section.
3591void DwarfDebug::emitDebugLocDWO() {
3592 if (getDwarfVersion() >= 5) {
3593 emitDebugLocImpl(
3594 Asm->getObjFileLowering().getDwarfLoclistsDWOSection());
3595
3596 return;
3597 }
3598
3599 for (const auto &List : DebugLocs.getLists()) {
3600 Asm->OutStreamer->switchSection(
3601 Asm->getObjFileLowering().getDwarfLocDWOSection());
3602 Asm->OutStreamer->emitLabel(List.Label);
3603
3604 for (const auto &Entry : DebugLocs.getEntries(List)) {
3605 // GDB only supports startx_length in pre-standard split-DWARF.
3606 // (in v5 standard loclists, it currently* /only/ supports base_address +
3607 // offset_pair, so the implementations can't really share much since they
3608 // need to use different representations)
3609 // * as of October 2018, at least
3610 //
3611 // In v5 (see emitLocList), this uses SectionLabels to reuse existing
3612 // addresses in the address pool to minimize object size/relocations.
3613 Asm->emitInt8(dwarf::DW_LLE_startx_length);
3614 unsigned idx = AddrPool.getIndex(Entry.Begin);
3615 Asm->emitULEB128(idx);
3616 // Also the pre-standard encoding is slightly different, emitting this as
3617 // an address-length entry here, but its a ULEB128 in DWARFv5 loclists.
3618 Asm->emitLabelDifference(Entry.End, Entry.Begin, 4);
3620 }
3621 Asm->emitInt8(dwarf::DW_LLE_end_of_list);
3622 }
3623}
3624
3627};
3628
3629// Emit a debug aranges section, containing a CU lookup for any
3630// address we can tie back to a CU.
3631void DwarfDebug::emitDebugARanges() {
3632 if (ArangeLabels.empty())
3633 return;
3634
3635 // Provides a unique id per text section.
3637
3638 // Filter labels by section.
3639 for (const SymbolCU &SCU : ArangeLabels) {
3640 if (SCU.Sym->isInSection()) {
3641 // Make a note of this symbol and it's section.
3642 MCSection *Section = &SCU.Sym->getSection();
3643 SectionMap[Section].push_back(SCU);
3644 } else {
3645 // Some symbols (e.g. common/bss on mach-o) can have no section but still
3646 // appear in the output. This sucks as we rely on sections to build
3647 // arange spans. We can do it without, but it's icky.
3648 SectionMap[nullptr].push_back(SCU);
3649 }
3650 }
3651
3652 DenseMap<DwarfCompileUnit *, std::vector<ArangeSpan>> Spans;
3653
3654 for (auto &I : SectionMap) {
3655 MCSection *Section = I.first;
3657 assert(!List.empty());
3658
3659 // If we have no section (e.g. common), just write out
3660 // individual spans for each symbol.
3661 if (!Section) {
3662 for (const SymbolCU &Cur : List) {
3663 ArangeSpan Span;
3664 Span.Start = Cur.Sym;
3665 Span.End = nullptr;
3666 assert(Cur.CU);
3667 Spans[Cur.CU].push_back(Span);
3668 }
3669 continue;
3670 }
3671
3672 // Insert a final terminator.
3673 List.push_back(SymbolCU(nullptr, Asm->OutStreamer->endSection(Section)));
3674
3675 // Build spans between each label.
3676 const MCSymbol *StartSym = List[0].Sym;
3677 for (size_t n = 1, e = List.size(); n < e; n++) {
3678 const SymbolCU &Prev = List[n - 1];
3679 const SymbolCU &Cur = List[n];
3680
3681 // Try and build the longest span we can within the same CU.
3682 if (Cur.CU != Prev.CU) {
3683 ArangeSpan Span;
3684 Span.Start = StartSym;
3685 Span.End = Cur.Sym;
3686 assert(Prev.CU);
3687 Spans[Prev.CU].push_back(Span);
3688 StartSym = Cur.Sym;
3689 }
3690 }
3691 }
3692
3693 // Start the dwarf aranges section.
3694 Asm->OutStreamer->switchSection(
3695 Asm->getObjFileLowering().getDwarfARangesSection());
3696
3697 unsigned PtrSize = Asm->MAI.getCodePointerSize();
3698
3699 // Build a list of CUs used.
3700 std::vector<DwarfCompileUnit *> CUs;
3701 for (const auto &it : Spans) {
3702 DwarfCompileUnit *CU = it.first;
3703 CUs.push_back(CU);
3704 }
3705
3706 // Sort the CU list (again, to ensure consistent output order).
3707 llvm::sort(CUs, [](const DwarfCompileUnit *A, const DwarfCompileUnit *B) {
3708 return A->getUniqueID() < B->getUniqueID();
3709 });
3710
3711 // Emit an arange table for each CU we used.
3712 for (DwarfCompileUnit *CU : CUs) {
3713 std::vector<ArangeSpan> &List = Spans[CU];
3714
3715 // Describe the skeleton CU's offset and length, not the dwo file's.
3716 if (auto *Skel = CU->getSkeleton())
3717 CU = Skel;
3718
3719 // Emit size of content not including length itself.
3720 unsigned ContentSize =
3721 sizeof(int16_t) + // DWARF ARange version number
3722 Asm->getDwarfOffsetByteSize() + // Offset of CU in the .debug_info
3723 // section
3724 sizeof(int8_t) + // Pointer Size (in bytes)
3725 sizeof(int8_t); // Segment Size (in bytes)
3726
3727 unsigned TupleSize = PtrSize * 2;
3728
3729 // 7.20 in the Dwarf specs requires the table to be aligned to a tuple.
3730 unsigned Padding = offsetToAlignment(
3731 Asm->getUnitLengthFieldByteSize() + ContentSize, Align(TupleSize));
3732
3733 ContentSize += Padding;
3734 ContentSize += (List.size() + 1) * TupleSize;
3735
3736 // For each compile unit, write the list of spans it covers.
3737 Asm->emitDwarfUnitLength(ContentSize, "Length of ARange Set");
3738 Asm->OutStreamer->AddComment("DWARF Arange version number");
3739 Asm->emitInt16(dwarf::DW_ARANGES_VERSION);
3740 Asm->OutStreamer->AddComment("Offset Into Debug Info Section");
3741 emitSectionReference(*CU);
3742 Asm->OutStreamer->AddComment("Address Size (in bytes)");
3743 Asm->emitInt8(PtrSize);
3744 Asm->OutStreamer->AddComment("Segment Size (in bytes)");
3745 Asm->emitInt8(0);
3746
3747 Asm->OutStreamer->emitFill(Padding, 0xff);
3748
3749 for (const ArangeSpan &Span : List) {
3750 Asm->emitLabelReference(Span.Start, PtrSize);
3751
3752 // Calculate the size as being from the span start to its end.
3753 //
3754 // If the size is zero, then round it up to one byte. The DWARF
3755 // specification requires that entries in this table have nonzero
3756 // lengths.
3757 auto SizeRef = SymSize.find(Span.Start);
3758 if ((SizeRef == SymSize.end() || SizeRef->second != 0) && Span.End) {
3759 Asm->emitLabelDifference(Span.End, Span.Start, PtrSize);
3760 } else {
3761 // For symbols without an end marker (e.g. common), we
3762 // write a single arange entry containing just that one symbol.
3763 uint64_t Size;
3764 if (SizeRef == SymSize.end() || SizeRef->second == 0)
3765 Size = 1;
3766 else
3767 Size = SizeRef->second;
3768
3769 Asm->OutStreamer->emitIntValue(Size, PtrSize);
3770 }
3771 }
3772
3773 Asm->OutStreamer->AddComment("ARange terminator");
3774 Asm->OutStreamer->emitIntValue(0, PtrSize);
3775 Asm->OutStreamer->emitIntValue(0, PtrSize);
3776 }
3777}
3778
3779/// Emit a single range list. We handle both DWARF v5 and earlier.
3781 const RangeSpanList &List) {
3782 emitRangeList(DD, Asm, List.Label, List.Ranges, *List.CU,
3783 dwarf::DW_RLE_base_addressx, dwarf::DW_RLE_offset_pair,
3784 dwarf::DW_RLE_startx_length, dwarf::DW_RLE_startx_endx,
3785 dwarf::DW_RLE_end_of_list, llvm::dwarf::RangeListEncodingString,
3786 List.CU->getCUNode()->getRangesBaseAddress() ||
3787 DD.getDwarfVersion() >= 5,
3788 [](auto) {});
3789}
3790
3791void DwarfDebug::emitDebugRangesImpl(const DwarfFile &Holder, MCSection *Section) {
3792 if (Holder.getRangeLists().empty())
3793 return;
3794
3796 assert(!CUMap.empty());
3797 assert(llvm::any_of(CUMap, [](const decltype(CUMap)::value_type &Pair) {
3798 return !Pair.second->getCUNode()->isDebugDirectivesOnly();
3799 }));
3800
3801 Asm->OutStreamer->switchSection(Section);
3802
3803 MCSymbol *TableEnd = nullptr;
3804 if (getDwarfVersion() >= 5)
3805 TableEnd = emitRnglistsTableHeader(Asm, Holder);
3806
3807 for (const RangeSpanList &List : Holder.getRangeLists())
3808 emitRangeList(*this, Asm, List);
3809
3810 if (TableEnd)
3811 Asm->OutStreamer->emitLabel(TableEnd);
3812}
3813
3814/// Emit address ranges into the .debug_ranges section or into the DWARF v5
3815/// .debug_rnglists section.
3816void DwarfDebug::emitDebugRanges() {
3817 const auto &Holder = useSplitDwarf() ? SkeletonHolder : InfoHolder;
3818
3819 emitDebugRangesImpl(Holder,
3820 getDwarfVersion() >= 5
3821 ? Asm->getObjFileLowering().getDwarfRnglistsSection()
3822 : Asm->getObjFileLowering().getDwarfRangesSection());
3823}
3824
3825void DwarfDebug::emitDebugRangesDWO() {
3826 emitDebugRangesImpl(InfoHolder,
3827 Asm->getObjFileLowering().getDwarfRnglistsDWOSection());
3828}
3829
3830/// Emit the header of a DWARF 5 macro section, or the GNU extension for
3831/// DWARF 4.
3832static void emitMacroHeader(AsmPrinter *Asm, const DwarfDebug &DD,
3833 const DwarfCompileUnit &CU, uint16_t DwarfVersion) {
3834 enum HeaderFlagMask {
3835#define HANDLE_MACRO_FLAG(ID, NAME) MACRO_FLAG_##NAME = ID,
3836#include "llvm/BinaryFormat/Dwarf.def"
3837 };
3838 Asm->OutStreamer->AddComment("Macro information version");
3839 Asm->emitInt16(DwarfVersion >= 5 ? DwarfVersion : 4);
3840 // We emit the line offset flag unconditionally here, since line offset should
3841 // be mostly present.
3842 if (Asm->isDwarf64()) {
3843 Asm->OutStreamer->AddComment("Flags: 64 bit, debug_line_offset present");
3844 Asm->emitInt8(MACRO_FLAG_OFFSET_SIZE | MACRO_FLAG_DEBUG_LINE_OFFSET);
3845 } else {
3846 Asm->OutStreamer->AddComment("Flags: 32 bit, debug_line_offset present");
3847 Asm->emitInt8(MACRO_FLAG_DEBUG_LINE_OFFSET);
3848 }
3849 Asm->OutStreamer->AddComment("debug_line_offset");
3850 if (DD.useSplitDwarf())
3851 Asm->emitDwarfLengthOrOffset(0);
3852 else
3853 Asm->emitDwarfSymbolReference(CU.getLineTableStartSym());
3854}
3855
3856void DwarfDebug::handleMacroNodes(DIMacroNodeArray Nodes, DwarfCompileUnit &U) {
3857 for (auto *MN : Nodes) {
3858 if (auto *M = dyn_cast<DIMacro>(MN))
3859 emitMacro(*M);
3860 else if (auto *F = dyn_cast<DIMacroFile>(MN))
3861 emitMacroFile(*F, U);
3862 else
3863 llvm_unreachable("Unexpected DI type!");
3864 }
3865}
3866
3867void DwarfDebug::emitMacro(DIMacro &M) {
3868 StringRef Name = M.getName();
3869 StringRef Value = M.getValue();
3870
3871 // There should be one space between the macro name and the macro value in
3872 // define entries. In undef entries, only the macro name is emitted.
3873 std::string Str = Value.empty() ? Name.str() : (Name + " " + Value).str();
3874
3875 if (UseDebugMacroSection) {
3876 if (getDwarfVersion() >= 5) {
3877 unsigned Type = M.getMacinfoType() == dwarf::DW_MACINFO_define
3878 ? dwarf::DW_MACRO_define_strx
3879 : dwarf::DW_MACRO_undef_strx;
3880 Asm->OutStreamer->AddComment(dwarf::MacroString(Type));
3881 Asm->emitULEB128(Type);
3882 Asm->OutStreamer->AddComment("Line Number");
3883 Asm->emitULEB128(M.getLine());
3884 Asm->OutStreamer->AddComment("Macro String");
3885 Asm->emitULEB128(
3886 InfoHolder.getStringPool().getIndexedEntry(*Asm, Str).getIndex());
3887 } else {
3888 unsigned Type = M.getMacinfoType() == dwarf::DW_MACINFO_define
3889 ? dwarf::DW_MACRO_GNU_define_indirect
3890 : dwarf::DW_MACRO_GNU_undef_indirect;
3891 Asm->OutStreamer->AddComment(dwarf::GnuMacroString(Type));
3892 Asm->emitULEB128(Type);
3893 Asm->OutStreamer->AddComment("Line Number");
3894 Asm->emitULEB128(M.getLine());
3895 Asm->OutStreamer->AddComment("Macro String");
3896 Asm->emitDwarfSymbolReference(
3897 InfoHolder.getStringPool().getEntry(*Asm, Str).getSymbol());
3898 }
3899 } else {
3900 Asm->OutStreamer->AddComment(dwarf::MacinfoString(M.getMacinfoType()));
3901 Asm->emitULEB128(M.getMacinfoType());
3902 Asm->OutStreamer->AddComment("Line Number");
3903 Asm->emitULEB128(M.getLine());
3904 Asm->OutStreamer->AddComment("Macro String");
3905 Asm->OutStreamer->emitBytes(Str);
3906 Asm->emitInt8('\0');
3907 }
3908}
3909
3910void DwarfDebug::emitMacroFileImpl(
3911 DIMacroFile &MF, DwarfCompileUnit &U, unsigned StartFile, unsigned EndFile,
3912 StringRef (*MacroFormToString)(unsigned Form)) {
3913
3914 Asm->OutStreamer->AddComment(MacroFormToString(StartFile));
3915 Asm->emitULEB128(StartFile);
3916 Asm->OutStreamer->AddComment("Line Number");
3917 Asm->emitULEB128(MF.getLine());
3918 Asm->OutStreamer->AddComment("File Number");
3919 DIFile &F = *MF.getFile();
3920 if (useSplitDwarf())
3921 Asm->emitULEB128(getDwoLineTable(U)->getFile(
3922 F.getDirectory(), F.getFilename(), getMD5AsBytes(&F),
3923 Asm->OutContext.getDwarfVersion(), F.getSource()));
3924 else
3925 Asm->emitULEB128(U.getOrCreateSourceID(&F));
3926 handleMacroNodes(MF.getElements(), U);
3927 Asm->OutStreamer->AddComment(MacroFormToString(EndFile));
3928 Asm->emitULEB128(EndFile);
3929}
3930
3931void DwarfDebug::emitMacroFile(DIMacroFile &F, DwarfCompileUnit &U) {
3932 // DWARFv5 macro and DWARFv4 macinfo share some common encodings,
3933 // so for readibility/uniformity, We are explicitly emitting those.
3934 assert(F.getMacinfoType() == dwarf::DW_MACINFO_start_file);
3935 if (UseDebugMacroSection)
3936 emitMacroFileImpl(
3937 F, U, dwarf::DW_MACRO_start_file, dwarf::DW_MACRO_end_file,
3939 else
3940 emitMacroFileImpl(F, U, dwarf::DW_MACINFO_start_file,
3942}
3943
3944void DwarfDebug::emitDebugMacinfoImpl(MCSection *Section) {
3945 for (const auto &P : CUMap) {
3946 auto &TheCU = *P.second;
3947 auto *SkCU = TheCU.getSkeleton();
3948 DwarfCompileUnit &U = SkCU ? *SkCU : TheCU;
3949 auto *CUNode = cast<DICompileUnit>(P.first);
3950 DIMacroNodeArray Macros = CUNode->getMacros();
3951 if (Macros.empty())
3952 continue;
3953 Asm->OutStreamer->switchSection(Section);
3954 Asm->OutStreamer->emitLabel(U.getMacroLabelBegin());
3955 if (UseDebugMacroSection)
3956 emitMacroHeader(Asm, *this, U, getDwarfVersion());
3957 handleMacroNodes(Macros, U);
3958 Asm->OutStreamer->AddComment("End Of Macro List Mark");
3959 Asm->emitInt8(0);
3960 }
3961}
3962
3963/// Emit macros into a debug macinfo/macro section.
3964void DwarfDebug::emitDebugMacinfo() {
3965 auto &ObjLower = Asm->getObjFileLowering();
3966 emitDebugMacinfoImpl(UseDebugMacroSection
3967 ? ObjLower.getDwarfMacroSection()
3968 : ObjLower.getDwarfMacinfoSection());
3969}
3970
3971void DwarfDebug::emitDebugMacinfoDWO() {
3972 auto &ObjLower = Asm->getObjFileLowering();
3973 emitDebugMacinfoImpl(UseDebugMacroSection
3974 ? ObjLower.getDwarfMacroDWOSection()
3975 : ObjLower.getDwarfMacinfoDWOSection());
3976}
3977
3978// DWARF5 Experimental Separate Dwarf emitters.
3979
3980void DwarfDebug::initSkeletonUnit(const DwarfUnit &U, DIE &Die,
3981 std::unique_ptr<DwarfCompileUnit> NewU) {
3982
3983 if (!CompilationDir.empty())
3984 NewU->addString(Die, dwarf::DW_AT_comp_dir, CompilationDir);
3985 addGnuPubAttributes(*NewU, Die);
3986
3987 SkeletonHolder.addUnit(std::move(NewU));
3988}
3989
3990DwarfCompileUnit &DwarfDebug::constructSkeletonCU(const DwarfCompileUnit &CU) {
3991
3992 auto OwnedUnit = std::make_unique<DwarfCompileUnit>(
3993 CU.getUniqueID(), CU.getCUNode(), Asm, this, &SkeletonHolder,
3995 DwarfCompileUnit &NewCU = *OwnedUnit;
3996 NewCU.setSection(Asm->getObjFileLowering().getDwarfInfoSection());
3997
3998 NewCU.initStmtList();
3999
4001 NewCU.addStringOffsetsStart();
4002
4003 initSkeletonUnit(CU, NewCU.getUnitDie(), std::move(OwnedUnit));
4004
4005 return NewCU;
4006}
4007
4008// Emit the .debug_info.dwo section for separated dwarf. This contains the
4009// compile units that would normally be in debug_info.
4010void DwarfDebug::emitDebugInfoDWO() {
4011 assert(useSplitDwarf() && "No split dwarf debug info?");
4012 // Don't emit relocations into the dwo file.
4013 InfoHolder.emitUnits(/* UseOffsets */ true);
4014}
4015
4016// Emit the .debug_abbrev.dwo section for separated dwarf. This contains the
4017// abbreviations for the .debug_info.dwo section.
4018void DwarfDebug::emitDebugAbbrevDWO() {
4019 assert(useSplitDwarf() && "No split dwarf?");
4020 InfoHolder.emitAbbrevs(Asm->getObjFileLowering().getDwarfAbbrevDWOSection());
4021}
4022
4023void DwarfDebug::emitDebugLineDWO() {
4024 assert(useSplitDwarf() && "No split dwarf?");
4025 SplitTypeUnitFileTable.Emit(
4026 *Asm->OutStreamer, MCDwarfLineTableParams(),
4027 Asm->getObjFileLowering().getDwarfLineDWOSection());
4028}
4029
4030void DwarfDebug::emitStringOffsetsTableHeaderDWO() {
4031 assert(useSplitDwarf() && "No split dwarf?");
4032 InfoHolder.getStringPool().emitStringOffsetsTableHeader(
4033 *Asm, Asm->getObjFileLowering().getDwarfStrOffDWOSection(),
4034 InfoHolder.getStringOffsetsStartSym());
4035}
4036
4037// Emit the .debug_str.dwo section for separated dwarf. This contains the
4038// string section and is identical in format to traditional .debug_str
4039// sections.
4040void DwarfDebug::emitDebugStrDWO() {
4042 emitStringOffsetsTableHeaderDWO();
4043 assert(useSplitDwarf() && "No split dwarf?");
4044 MCSection *OffSec = Asm->getObjFileLowering().getDwarfStrOffDWOSection();
4045 InfoHolder.emitStrings(Asm->getObjFileLowering().getDwarfStrDWOSection(),
4046 OffSec, /* UseRelativeOffsets = */ false);
4047}
4048
4049// Emit address pool.
4050void DwarfDebug::emitDebugAddr() {
4051 AddrPool.emit(*Asm, Asm->getObjFileLowering().getDwarfAddrSection());
4052}
4053
4054MCDwarfDwoLineTable *DwarfDebug::getDwoLineTable(const DwarfCompileUnit &CU) {
4055 if (!useSplitDwarf())
4056 return nullptr;
4057 const DICompileUnit *DIUnit = CU.getCUNode();
4058 SplitTypeUnitFileTable.maybeSetRootFile(
4059 DIUnit->getDirectory(), DIUnit->getFilename(),
4060 getMD5AsBytes(DIUnit->getFile()), DIUnit->getSource());
4061 return &SplitTypeUnitFileTable;
4062}
4063
4065 MD5 Hash;
4066 Hash.update(Identifier);
4067 // ... take the least significant 8 bytes and return those. Our MD5
4068 // implementation always returns its results in little endian, so we actually
4069 // need the "high" word.
4070 MD5::MD5Result Result;
4071 Hash.final(Result);
4072 return Result.high();
4073}
4074
4076 StringRef Identifier, DIE &RefDie,
4077 const DICompositeType *CTy) {
4078 // Fast path if we're building some type units and one has already used the
4079 // address pool we know we're going to throw away all this work anyway, so
4080 // don't bother building dependent types.
4081 if (!TypeUnitsUnderConstruction.empty() && AddrPool.hasBeenUsed())
4082 return;
4083
4084 auto Ins = TypeSignatures.try_emplace(CTy);
4085 if (!Ins.second) {
4086 CU.addDIETypeSignature(RefDie, Ins.first->second);
4087 return;
4088 }
4089
4091 bool TopLevelType = TypeUnitsUnderConstruction.empty();
4092 AddrPool.resetUsedFlag();
4093
4094 auto OwnedUnit = std::make_unique<DwarfTypeUnit>(
4095 CU, Asm, this, &InfoHolder, NumTypeUnitsCreated++, getDwoLineTable(CU));
4096 DwarfTypeUnit &NewTU = *OwnedUnit;
4097 DIE &UnitDie = NewTU.getUnitDie();
4098 TypeUnitsUnderConstruction.emplace_back(std::move(OwnedUnit), CTy);
4099
4100 NewTU.addUInt(UnitDie, dwarf::DW_AT_language, dwarf::DW_FORM_data2,
4101 CU.getSourceLanguage());
4102
4103 uint64_t Signature = makeTypeSignature(Identifier);
4104 NewTU.setTypeSignature(Signature);
4105 Ins.first->second = Signature;
4106
4107 if (useSplitDwarf()) {
4108 // Although multiple type units can have the same signature, they are not
4109 // guranteed to be bit identical. When LLDB uses .debug_names it needs to
4110 // know from which CU a type unit came from. These two attrbutes help it to
4111 // figure that out.
4112 if (getDwarfVersion() >= 5) {
4113 if (!CompilationDir.empty())
4114 NewTU.addString(UnitDie, dwarf::DW_AT_comp_dir, CompilationDir);
4115 NewTU.addString(UnitDie, dwarf::DW_AT_dwo_name,
4116 Asm->TM.Options.MCOptions.SplitDwarfFile);
4117 }
4118 MCSection *Section =
4119 getDwarfVersion() <= 4
4120 ? Asm->getObjFileLowering().getDwarfTypesDWOSection()
4121 : Asm->getObjFileLowering().getDwarfInfoDWOSection();
4122 NewTU.setSection(Section);
4123 } else {
4124 MCSection *Section =
4125 getDwarfVersion() <= 4
4126 ? Asm->getObjFileLowering().getDwarfTypesSection(Signature)
4127 : Asm->getObjFileLowering().getDwarfInfoSection(Signature);
4128 NewTU.setSection(Section);
4129 // Non-split type units reuse the compile unit's line table.
4130 CU.applyStmtList(UnitDie);
4131 }
4132
4133 // Add DW_AT_str_offsets_base to the type unit DIE, but not for split type
4134 // units.
4136 NewTU.addStringOffsetsStart();
4137
4138 NewTU.setType(NewTU.createTypeDIE(CTy));
4139
4140 if (TopLevelType) {
4141 auto TypeUnitsToAdd = std::move(TypeUnitsUnderConstruction);
4142 TypeUnitsUnderConstruction.clear();
4143
4144 // Types referencing entries in the address table cannot be placed in type
4145 // units.
4146 if (AddrPool.hasBeenUsed()) {
4147 AccelTypeUnitsDebugNames.clear();
4148 // Remove all the types built while building this type.
4149 // This is pessimistic as some of these types might not be dependent on
4150 // the type that used an address.
4151 for (const auto &TU : TypeUnitsToAdd)
4152 TypeSignatures.erase(TU.second);
4153
4154 // Construct this type in the CU directly.
4155 // This is inefficient because all the dependent types will be rebuilt
4156 // from scratch, including building them in type units, discovering that
4157 // they depend on addresses, throwing them out and rebuilding them.
4159 CU.constructTypeDIE(RefDie, cast<DICompositeType>(CTy));
4160 CU.updateAcceleratorTables(CTy->getScope(), CTy, RefDie);
4161 return;
4162 }
4163
4164 // If the type wasn't dependent on fission addresses, finish adding the type
4165 // and all its dependent types.
4166 for (auto &TU : TypeUnitsToAdd) {
4167 InfoHolder.computeSizeAndOffsetsForUnit(TU.first.get());
4168 InfoHolder.emitUnit(TU.first.get(), useSplitDwarf());
4169 if (getDwarfVersion() >= 5 &&
4171 if (useSplitDwarf())
4172 AccelDebugNames.addTypeUnitSignature(*TU.first);
4173 else
4174 AccelDebugNames.addTypeUnitSymbol(*TU.first);
4175 }
4176 }
4177 AccelTypeUnitsDebugNames.convertDieToOffset();
4178 AccelDebugNames.addTypeEntries(AccelTypeUnitsDebugNames);
4179 AccelTypeUnitsDebugNames.clear();
4181 }
4182 CU.addDIETypeSignature(RefDie, Signature);
4183}
4184
4185// Add the Name along with its companion DIE to the appropriate accelerator
4186// table (for AccelTableKind::Dwarf it's always AccelDebugNames, for
4187// AccelTableKind::Apple, we use the table we got as an argument). If
4188// accelerator tables are disabled, this function does nothing.
4189template <typename DataT>
4190void DwarfDebug::addAccelNameImpl(
4191 const DwarfUnit &Unit,
4192 const DICompileUnit::DebugNameTableKind NameTableKind,
4193 AccelTable<DataT> &AppleAccel, StringRef Name, const DIE &Die) {
4195 Unit.getUnitDie().getTag() == dwarf::DW_TAG_skeleton_unit || Name.empty())
4196 return;
4197
4201 return;
4202
4203 DwarfFile &Holder = useSplitDwarf() ? SkeletonHolder : InfoHolder;
4205
4206 switch (getAccelTableKind()) {
4208 AppleAccel.addName(Ref, Die);
4209 break;
4210 case AccelTableKind::Dwarf: {
4212 assert(((&Current == &AccelTypeUnitsDebugNames) ||
4213 ((&Current == &AccelDebugNames) &&
4214 (Unit.getUnitDie().getTag() != dwarf::DW_TAG_type_unit))) &&
4215 "Kind is CU but TU is being processed.");
4216 assert(((&Current == &AccelDebugNames) ||
4217 ((&Current == &AccelTypeUnitsDebugNames) &&
4218 (Unit.getUnitDie().getTag() == dwarf::DW_TAG_type_unit))) &&
4219 "Kind is TU but CU is being processed.");
4220 // The type unit can be discarded, so need to add references to final
4221 // acceleration table once we know it's complete and we emit it.
4222 Current.addName(Ref, Die, Unit.getUniqueID(),
4223 Unit.getUnitDie().getTag() == dwarf::DW_TAG_type_unit);
4224 break;
4225 }
4227 llvm_unreachable("Default should have already been resolved.");
4229 llvm_unreachable("None handled above");
4230 }
4231}
4232
4234 const DwarfUnit &Unit,
4235 const DICompileUnit::DebugNameTableKind NameTableKind, StringRef Name,
4236 const DIE &Die) {
4237 addAccelNameImpl(Unit, NameTableKind, AccelNames, Name, Die);
4238}
4239
4241 const DwarfUnit &Unit,
4242 const DICompileUnit::DebugNameTableKind NameTableKind, StringRef Name,
4243 const DIE &Die) {
4244 // ObjC names go only into the Apple accelerator tables.
4246 addAccelNameImpl(Unit, NameTableKind, AccelObjC, Name, Die);
4247}
4248
4250 const DwarfUnit &Unit,
4251 const DICompileUnit::DebugNameTableKind NameTableKind, StringRef Name,
4252 const DIE &Die) {
4253 addAccelNameImpl(Unit, NameTableKind, AccelNamespace, Name, Die);
4254}
4255
4257 const DwarfUnit &Unit,
4258 const DICompileUnit::DebugNameTableKind NameTableKind, StringRef Name,
4259 const DIE &Die, char Flags) {
4260 addAccelNameImpl(Unit, NameTableKind, AccelTypes, Name, Die);
4261}
4262
4264 return Asm->OutStreamer->getContext().getDwarfVersion();
4265}
4266
4268 if (Asm->getDwarfVersion() >= 4)
4269 return dwarf::Form::DW_FORM_sec_offset;
4270 assert((!Asm->isDwarf64() || (Asm->getDwarfVersion() == 3)) &&
4271 "DWARF64 is not defined prior DWARFv3");
4272 return Asm->isDwarf64() ? dwarf::Form::DW_FORM_data8
4273 : dwarf::Form::DW_FORM_data4;
4274}
4275
4277 return SectionLabels.lookup(S);
4278}
4279
4281 if (SectionLabels.insert(std::make_pair(&S->getSection(), S)).second)
4282 if (useSplitDwarf() || getDwarfVersion() >= 5)
4283 AddrPool.getIndex(S);
4284}
4285
4286std::optional<MD5::MD5Result>
4288 assert(File);
4289 if (getDwarfVersion() < 5)
4290 return std::nullopt;
4291 std::optional<DIFile::ChecksumInfo<StringRef>> Checksum = File->getChecksum();
4292 if (!Checksum || Checksum->Kind != DIFile::CSK_MD5)
4293 return std::nullopt;
4294
4295 // Convert the string checksum to an MD5Result for the streamer.
4296 // The verifier validates the checksum so we assume it's okay.
4297 // An MD5 checksum is 16 bytes.
4298 std::string ChecksumString = fromHex(Checksum->Value);
4299 MD5::MD5Result CKMem;
4300 llvm::copy(ChecksumString, CKMem.data());
4301 return CKMem;
4302}
4303
4305 if (MinimizeAddr == MinimizeAddrInV5::Ranges)
4306 return true;
4307 if (MinimizeAddr != MinimizeAddrInV5::Default)
4308 return false;
4309 if (useSplitDwarf())
4310 return true;
4311 return false;
4312}
4313
4315 if (MBB.getAlignment() == Align(1))
4316 return;
4317
4318 auto *SP = MBB.getParent()->getFunction().getSubprogram();
4319 bool NoDebug =
4320 !SP || SP->getUnit()->getEmissionKind() == DICompileUnit::NoDebug;
4321
4322 if (NoDebug)
4323 return;
4324
4325 auto PrevLoc = Asm->OutStreamer->getContext().getCurrentDwarfLoc();
4326 if (PrevLoc.getLine()) {
4327 Asm->OutStreamer->emitDwarfLocDirective(
4328 PrevLoc.getFileNum(), 0, PrevLoc.getColumn(), 0, 0, 0, StringRef());
4329 MCDwarfLineEntry::make(Asm->OutStreamer.get(),
4330 Asm->OutStreamer->getCurrentSectionOnly());
4331 }
4332}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file implements a class to represent arbitrary precision integral constant values and operations...
MachineBasicBlock & MBB
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
BitTracker BT
static Expected< bool > hasObjCCategory(BitstreamCursor &Stream)
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define clEnumValN(ENUMVAL, FLAGNAME, DESC)
#define clEnumVal(ENUMVAL, DESC)
This file contains the declarations for the subclasses of Constant, which represent the different fla...
DXIL Finalize Linkage
dxil translate DXIL Translate Metadata
@ EndOfList
static bool isObjCClass(StringRef Name)
static cl::opt< bool > NoDwarfRangesSection("no-dwarf-ranges-section", cl::Hidden, cl::desc("Disable emission .debug_ranges section."), cl::init(false))
static void finishCallSiteParams(ValT Val, const DIExpression *Expr, ArrayRef< FwdRegParamInfo > DescribedParams, ParamSet &Params)
Emit call site parameter entries that are described by the given value and debug expression.
static cl::opt< bool > UseGNUDebugMacro("use-gnu-debug-macro", cl::Hidden, cl::desc("Emit the GNU .debug_macro format with DWARF <5"), cl::init(false))
static cl::opt< DefaultOnOff > DwarfInlinedStrings("dwarf-inlined-strings", cl::Hidden, cl::desc("Use inlined strings rather than string section."), cl::values(clEnumVal(Default, "Default for platform"), clEnumVal(Enable, "Enabled"), clEnumVal(Disable, "Disabled")), cl::init(Default))
static bool validThroughout(LexicalScopes &LScopes, const MachineInstr *DbgValue, const MachineInstr *RangeEnd, const InstructionOrdering &Ordering)
Determine whether a singular DBG_VALUE is valid for the entirety of its enclosing lexical scope.
static cl::opt< bool > GenerateARangeSection("generate-arange-section", cl::Hidden, cl::desc("Generate dwarf aranges"), cl::init(false))
static cl::opt< LinkageNameOption > DwarfLinkageNames("dwarf-linkage-names", cl::Hidden, cl::desc("Which DWARF linkage-name attributes to emit."), cl::values(clEnumValN(DefaultLinkageNames, "Default", "Default for platform"), clEnumValN(AllLinkageNames, "All", "All"), clEnumValN(AbstractLinkageNames, "Abstract", "Abstract subprograms")), cl::init(DefaultLinkageNames))
static void addToFwdRegWorklist(FwdRegWorklist &Worklist, unsigned Reg, const DIExpression *Expr, ArrayRef< FwdRegParamInfo > ParamsToAdd)
Add Reg to the worklist, if it's not already present, and mark that the given parameter registers' va...
static cl::opt< bool > GenerateDwarfTypeUnits("generate-type-units", cl::Hidden, cl::desc("Generate DWARF4 type units."), cl::init(false))
SmallSet< MCRegUnit, 16 > ClobberedRegUnitSet
Container for the set of register units known to be clobbered on the path to a call site.
static cl::opt< bool > KeyInstructionsAreStmts("dwarf-use-key-instructions", cl::Hidden, cl::init(true), cl::desc("Set to false to ignore Key Instructions metadata"))
Set to false to ignore Key Instructions metadata.
static bool interpretNextInstr(const MachineInstr *CurMI, FwdRegWorklist &ForwardedRegWorklist, ParamSet &Params, ClobberedRegUnitSet &ClobberedRegUnits)
static SmallVectorImpl< DwarfCompileUnit::GlobalExpr > & sortGlobalExprs(SmallVectorImpl< DwarfCompileUnit::GlobalExpr > &GVEs)
Sort and unique GVEs by comparing their fragment offset.
LinkageNameOption
@ DefaultLinkageNames
@ AbstractLinkageNames
@ AllLinkageNames
static dwarf::PubIndexEntryDescriptor computeIndexValue(DwarfUnit *CU, const DIE *Die)
computeIndexValue - Compute the gdb index value for the DIE and CU.
static uint64_t getFragmentOffsetInBits(const DIExpression &Expr)
static cl::opt< DefaultOnOff > DwarfOpConvert("dwarf-op-convert", cl::Hidden, cl::desc("Enable use of the DWARFv5 DW_OP_convert operator"), cl::values(clEnumVal(Default, "Default for platform"), clEnumVal(Enable, "Enabled"), clEnumVal(Disable, "Disabled")), cl::init(Default))
static std::pair< const MachineInstr *, bool > findPrologueEndLoc(const MachineFunction *MF)
static void collectCallSiteParameters(const MachineInstr *CallMI, ParamSet &Params)
Try to interpret values loaded into registers that forward parameters for CallMI.
static MCSymbol * emitRnglistsTableHeader(AsmPrinter *Asm, const DwarfFile &Holder)
static cl::opt< bool > SplitDwarfCrossCuReferences("split-dwarf-cross-cu-references", cl::Hidden, cl::desc("Enable cross-cu references in DWO files"), cl::init(false))
static cl::opt< bool > UseDwarfRangesBaseAddressSpecifier("use-dwarf-ranges-base-address-specifier", cl::Hidden, cl::desc("Use base address specifiers in debug_ranges"), cl::init(false))
MapVector< Register, SmallVector< FwdRegParamInfo, 2 > > FwdRegWorklist
Register worklist for finding call site values.
static void emitLocList(DwarfDebug &DD, AsmPrinter *Asm, const DebugLocStream::List &List)
static constexpr unsigned ULEB128PadSize
static cl::opt< DefaultOnOff > DwarfSectionsAsReferences("dwarf-sections-as-references", cl::Hidden, cl::desc("Use sections+offset as references rather than labels."), cl::values(clEnumVal(Default, "Default for platform"), clEnumVal(Enable, "Enabled"), clEnumVal(Disable, "Disabled")), cl::init(Default))
DefaultOnOff
@ Default
@ Enable
@ Disable
static AccelTableKind computeAccelTableKind(unsigned DwarfVersion, bool GenerateTypeUnits, DebuggerKind Tuning, const Triple &TT)
static void emitRangeList(DwarfDebug &DD, AsmPrinter *Asm, MCSymbol *Sym, const Ranges &R, const DwarfCompileUnit &CU, unsigned BaseAddressx, unsigned OffsetPair, unsigned StartxLength, unsigned StartxEndx, unsigned EndOfList, StringRef(*StringifyEnum)(unsigned), bool ShouldUseBaseAddress, PayloadEmitter EmitPayload)
static void forBothCUs(DwarfCompileUnit &CU, Func F)
static MCSymbol * emitLoclistsTableHeader(AsmPrinter *Asm, const DwarfDebug &DD)
static const DILocalScope * getRetainedNodeScope(const MDNode *N)
static const DIExpression * combineDIExpressions(const DIExpression *Original, const DIExpression *Addition)
Append the expression Addition to Original and return the result.
static void interpretValues(const MachineInstr *CurMI, FwdRegWorklist &ForwardedRegWorklist, ParamSet &Params, ClobberedRegUnitSet &ClobberedRegUnits)
Interpret values loaded into registers by CurMI.
static cl::opt< DefaultOnOff > UnknownLocations("use-unknown-locations", cl::Hidden, cl::desc("Make an absence of debug location information explicit."), cl::values(clEnumVal(Default, "At top of block or after label"), clEnumVal(Enable, "In all cases"), clEnumVal(Disable, "Never")), cl::init(Default))
static void recordSourceLine(AsmPrinter &Asm, unsigned Line, unsigned Col, const MDNode *S, unsigned Flags, unsigned CUID, uint16_t DwarfVersion, ArrayRef< std::unique_ptr< DwarfCompileUnit > > DCUs, StringRef Comment={})
Register a source line with debug info.
static void emitMacroHeader(AsmPrinter *Asm, const DwarfDebug &DD, const DwarfCompileUnit &CU, uint16_t DwarfVersion)
Emit the header of a DWARF 5 macro section, or the GNU extension for DWARF 4.
static cl::opt< AccelTableKind > AccelTables("accel-tables", cl::Hidden, cl::desc("Output dwarf accelerator tables."), cl::values(clEnumValN(AccelTableKind::Default, "Default", "Default for platform"), clEnumValN(AccelTableKind::None, "Disable", "Disabled."), clEnumValN(AccelTableKind::Apple, "Apple", "Apple"), clEnumValN(AccelTableKind::Dwarf, "Dwarf", "DWARF")), cl::init(AccelTableKind::Default))
static cl::opt< DwarfDebug::MinimizeAddrInV5 > MinimizeAddrInV5Option("minimize-addr-in-v5", cl::Hidden, cl::desc("Always use DW_AT_ranges in DWARFv5 whenever it could allow more " "address pool entry sharing to reduce relocations/object size"), cl::values(clEnumValN(DwarfDebug::MinimizeAddrInV5::Default, "Default", "Default address minimization strategy"), clEnumValN(DwarfDebug::MinimizeAddrInV5::Ranges, "Ranges", "Use rnglists for contiguous ranges if that allows " "using a pre-existing base address"), clEnumValN(DwarfDebug::MinimizeAddrInV5::Expressions, "Expressions", "Use exprloc addrx+offset expressions for any " "address with a prior base address"), clEnumValN(DwarfDebug::MinimizeAddrInV5::Form, "Form", "Use addrx+offset extension form for any address " "with a prior base address"), clEnumValN(DwarfDebug::MinimizeAddrInV5::Disabled, "Disabled", "Stuff")), cl::init(DwarfDebug::MinimizeAddrInV5::Default))
static StringRef getObjCMethodName(StringRef In)
static DbgValueLoc getDebugLocValue(const MachineInstr *MI)
Get .debug_loc entry for the instruction range starting at MI.
static void getObjCClassCategory(StringRef In, StringRef &Class, StringRef &Category)
const HexagonInstrInfo * TII
#define _
IRTranslator LLVM IR MI
Module.h This file contains the declarations for the Module class.
#define DWARF2_FLAG_IS_STMT
Definition MCDwarf.h:119
#define DWARF2_FLAG_PROLOGUE_END
Definition MCDwarf.h:121
#define DWARF2_FLAG_EPILOGUE_BEGIN
Definition MCDwarf.h:122
#define F(x, y, z)
Definition MD5.cpp:54
#define I(x, y, z)
Definition MD5.cpp:57
Register Reg
Register const TargetRegisterInfo * TRI
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
#define P(N)
if(PassOpts->AAPipeline)
static const MCPhysReg CalleeSavedReg
const SmallVectorImpl< MachineOperand > MachineBasicBlock * TBB
const SmallVectorImpl< MachineOperand > & Cond
This file defines the 'Statistic' class, which is designed to be an easy way to expose various metric...
#define STATISTIC(VARNAME, DESC)
Definition Statistic.h:171
This file contains some functions that are useful when dealing with strings.
#define LLVM_DEBUG(...)
Definition Debug.h:119
This file describes how to lower LLVM code to machine code.
static bool isCopy(MachineInstr *MI)
Value * RHS
Value * LHS
static const uint32_t IV[8]
Definition blake3_impl.h:83
Class recording the (high level) value of a variable.
Class for arbitrary precision integers.
Definition APInt.h:78
This class holds an abstract representation of an Accelerator Table, consisting of a sequence of buck...
Definition AccelTable.h:203
void addName(DwarfStringPoolEntryRef Name, Types &&... Args)
Definition AccelTable.h:216
unsigned getIndex(const MCSymbol *Sym, bool TLS=false)
Returns the index into the address pool with the given label/symbol.
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
std::vector< T > vec() const
Definition ArrayRef.h:270
This class is intended to be used as a driving class for all asm writers.
Definition AsmPrinter.h:91
DwarfDebug * getDwarfDebug()
Definition AsmPrinter.h:290
TargetMachine & TM
Target machine description.
Definition AsmPrinter.h:94
MachineFunction * MF
The current machine function.
Definition AsmPrinter.h:109
std::unique_ptr< MCStreamer > OutStreamer
This is the MCStreamer object for the file we are generating.
Definition AsmPrinter.h:106
const MCAsmInfo & MAI
Target Asm Printer information.
Definition AsmPrinter.h:97
uint16_t getDwarfVersion() const
virtual void emitInt8(uint8_t Byte, const Twine &Comment="")=0
virtual unsigned emitDIERef(const DIE &D)=0
Basic type, like 'int' or 'float'.
bool getDebugInfoForProfiling() const
bool isDebugDirectivesOnly() const
StringRef getFlags() const
StringRef getSDK() const
static LLVM_ABI std::optional< DebugNameTableKind > getNameTableKind(StringRef Str)
unsigned getRuntimeVersion() const
bool getSplitDebugInlining() const
StringRef getSysRoot() const
StringRef getProducer() const
DISourceLanguageName getSourceLanguage() const
uint64_t getDWOId() const
StringRef getSplitDebugFilename() const
static LLVM_ABI std::optional< DebugEmissionKind > getEmissionKind(StringRef Str)
void setSection(MCSection *Section)
Set the section that this DIEUnit will be emitted into.
Definition DIE.h:994
DIE & getUnitDie()
Definition DIE.h:1009
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
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
dwarf::Tag getTag() const
Definition DIE.h:864
Holds a DIExpression and keeps track of how many operands have been consumed so far.
DWARF expression.
static LLVM_ABI DIExpression * append(const DIExpression *Expr, ArrayRef< uint64_t > Ops)
Append the opcodes Ops to DIExpr.
unsigned getNumElements() const
LLVM_ABI bool isImplicit() const
Return whether this is an implicit location description.
static LLVM_ABI std::optional< FragmentInfo > getFragmentInfo(expr_op_iterator Start, expr_op_iterator End)
Retrieve the details of this fragment expression.
static LLVM_ABI std::optional< const DIExpression * > convertToNonVariadicExpression(const DIExpression *Expr)
If Expr is a valid single-location expression, i.e.
ArrayRef< uint64_t > getElements() const
LLVM_ABI bool isValid() const
A scope for locals.
LLVM_ABI DILocalScope * getNonLexicalBlockFileScope() const
Get the first non DILexicalBlockFile scope of this scope.
uint64_t getAtomGroup() const
uint8_t getAtomRank() const
DIFile * getFile() const
unsigned getLine() const
DIMacroNodeArray getElements() const
Tagged DWARF-like metadata node.
StringRef getFilename() const
DIFile * getFile() const
StringRef getDirectory() const
std::optional< StringRef > getSource() const
Subprogram description. Uses SubclassData1.
static LLVM_ABI DILocalScope * getRetainedNodeScope(MDNode *N)
Base class for types.
DIScope * getScope() const
DIType * getType() const
A DWARFDataExtractor (typically for an in-memory copy of an object-file section) plus a relocation ma...
Encoding
Size and signedness of expression operations' operands.
Used for tracking debug info about call site parameters.
Definition DwarfDebug.h:317
This class is defined as the common parent of DbgVariable and DbgLabel such that it could levarage po...
Definition DwarfDebug.h:66
A single location or constant within a variable location description, with either a single entry (wit...
The location of a single variable, composed of an expression and 0 or more DbgValueLocEntries.
const DILocalVariable * getVariable() const
Definition DwarfDebug.h:247
const DIType * getType() const
const MachineInstr * CurMI
If nonnull, stores the current machine instruction we're processing.
AsmPrinter * Asm
Target of debug info emission.
MCSymbol * getLabelBeforeInsn(const MachineInstr *MI)
Return Label preceding the instruction.
MachineModuleInfo * MMI
Collected machine module information.
DebugLoc PrevInstLoc
Previous instruction's location information.
MCSymbol * getLabelAfterInsn(const MachineInstr *MI)
Return Label immediately following the instruction.
void beginInstruction(const MachineInstr *MI) override
Process beginning of an instruction.
const MachineBasicBlock * PrevInstBB
void requestLabelAfterInsn(const MachineInstr *MI)
Ensure that a label will be emitted after MI.
DbgValueHistoryMap DbgValues
History of DBG_VALUE and clobber instructions for each user variable.
DbgLabelInstrMap DbgLabels
Mapping of inlined labels and DBG_LABEL machine instruction.
void beginModule(Module *M) override
const InstructionOrdering & getInstOrdering() const
void requestLabelBeforeInsn(const MachineInstr *MI)
Ensure that a label will be emitted before MI.
const MachineBasicBlock * EpilogBeginBlock
This block includes epilogue instructions.
const MachineInstr * PrologEndLoc
This location indicates end of function prologue and beginning of function body.
DwarfExpression implementation for .debug_loc entries.
void finalize(const AsmPrinter &AP, DebugLocStream::ListBuilder &List, const DIBasicType *BT, DwarfCompileUnit &TheCU)
Lower this entry into a DWARF expression.
Builder for DebugLocStream entries.
Builder for DebugLocStream lists.
ArrayRef< Entry > getEntries(const List &L) const
A debug info location.
Definition DebugLoc.h:126
LLVM_ABI unsigned getLine() const
Definition DebugLoc.cpp:43
ValueT lookup(const_arg_type_t< KeyT > Val) const
Return the entry for the specified key, or a default constructed value if no such entry exists.
Definition DenseMap.h:250
iterator find(const_arg_type_t< KeyT > Val)
Definition DenseMap.h:223
bool erase(const KeyT &Val)
Definition DenseMap.h:377
iterator end()
Definition DenseMap.h:141
std::pair< iterator, bool > insert(const std::pair< KeyT, ValueT > &KV)
Definition DenseMap.h:284
Implements a dense probed hash-table based set.
Definition DenseSet.h:281
void addRange(RangeSpan Range)
addRange - Add an address range to the list of ranges for this unit.
DIE & constructSubprogramScopeDIE(const DISubprogram *Sub, const Function &F, LexicalScope *Scope, MCSymbol *LineTableSym)
Construct a DIE for this subprogram scope.
void createAbstractEntity(const DINode *Node, LexicalScope *Scope)
DwarfCompileUnit * getSkeleton() const
void setSkeleton(DwarfCompileUnit &Skel)
Set the skeleton unit associated with this unit.
const StringMap< const DIE * > & getGlobalNames() const
DbgEntity * getExistingAbstractEntity(const DINode *Node)
const StringMap< const DIE * > & getGlobalTypes() const
Collects and handles dwarf debug information.
Definition DwarfDebug.h:352
bool useSegmentedStringOffsetsTable() const
Returns whether to generate a string offsets table with (possibly shared) contributions from each CU ...
Definition DwarfDebug.h:884
virtual bool shouldResetBaseAddress(const MCSection &Section) const
Whether the target requires resetting the base address in range/loc lists.
Definition DwarfDebug.h:751
std::optional< MD5::MD5Result > getMD5AsBytes(const DIFile *File) const
If the File has an MD5 checksum, return it as an MD5Result allocated in the MCContext.
virtual bool shouldAttachCompileUnitRanges() const
Whether to attach ranges/low_pc to the compile unit DIE in endModule.
Definition DwarfDebug.h:732
bool emitDebugEntryValues() const
Definition DwarfDebug.h:888
uint16_t getDwarfVersion() const
Returns the Dwarf Version.
void emitDebugLocEntry(ByteStreamer &Streamer, const DebugLocStream::Entry &Entry, const DwarfCompileUnit *CU)
Emit an entry for the debug loc section.
void addAccelNamespace(const DwarfUnit &Unit, const DICompileUnit::DebugNameTableKind NameTableKind, StringRef Name, const DIE &Die)
void setCurrentDWARF5AccelTable(const DWARF5AccelTableKind Kind)
Sets the current DWARF5AccelTable to use.
bool alwaysUseRanges(const DwarfCompileUnit &) const
Returns whether range encodings should be used for single entry range lists.
void beginModule(Module *M) override
Emit all Dwarf sections that should come prior to the content.
void addSubprogramNames(const DwarfUnit &Unit, const DICompileUnit::DebugNameTableKind NameTableKind, const DISubprogram *SP, DIE &Die)
bool useAllLinkageNames() const
Returns whether we should emit all DW_AT_[MIPS_]linkage_name.
Definition DwarfDebug.h:822
void insertSectionLabel(const MCSymbol *S)
void addAccelObjC(const DwarfUnit &Unit, const DICompileUnit::DebugNameTableKind NameTableKind, StringRef Name, const DIE &Die)
dwarf::Form getDwarfSectionOffsetForm() const
Returns a suitable DWARF form to represent a section offset, i.e.
bool useAppleExtensionAttributes() const
Definition DwarfDebug.h:870
void skippedNonDebugFunction() override
void addArangeLabel(SymbolCU SCU)
Add a label so that arange data can be generated for it.
Definition DwarfDebug.h:809
virtual void finishTargetUnitAttributes(const DICompileUnit &DIUnit, DwarfCompileUnit &NewCU)
Target-specific compile unit attribute finalization.
Definition DwarfDebug.h:738
void beginInstruction(const MachineInstr *MI) override
Process beginning of an instruction.
AddressPool & getAddressPool()
Definition DwarfDebug.h:931
DWARF5AccelTable & getCurrentDWARF5AccelTable()
Returns either CU or TU DWARF5AccelTable.
bool useSectionsAsReferences() const
Returns whether to use sections as labels rather than temp symbols.
Definition DwarfDebug.h:855
const DebugLocStream & getDebugLocs() const
Returns the entries for the .debug_loc section.
Definition DwarfDebug.h:915
bool shareAcrossDWOCUs() const
void terminateLineTable(const DwarfCompileUnit *CU)
Terminate the line table by adding the last range label.
~DwarfDebug() override
void endFunctionImpl(const MachineFunction *MF) override
Gather and emit post-function debug information.
DwarfCompileUnit & getOrCreateAbstractSubprogramCU(const DISubprogram *SP, DwarfCompileUnit &SrcCU)
Find the matching DwarfCompileUnit for the given SP referenced from SrcCU.
void emitDebugLocEntryLocation(const DebugLocStream::Entry &Entry, const DwarfCompileUnit *CU)
Emit the location for a debug loc entry, including the size header.
const SmallVectorImpl< std::unique_ptr< DwarfCompileUnit > > & getUnits()
Definition DwarfDebug.h:741
const MCSymbol * getSectionLabel(const MCSection *S)
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:876
virtual void initializeTargetDebugInfo(const MachineFunction &MF)
Target-specific debug info initialization at function start.
Definition DwarfDebug.h:723
unsigned getDwarfCompileUnitIDForLineTable(const DwarfCompileUnit &CU)
Get Dwarf compile unit ID for line table.
const MachineInstr * emitInitialLocDirective(const MachineFunction &MF, unsigned CUID)
Emits inital debug location directive.
bool useRangesSection() const
Returns whether ranges section should be emitted.
Definition DwarfDebug.h:836
void addAccelName(const DwarfUnit &Unit, const DICompileUnit::DebugNameTableKind NameTableKind, StringRef Name, const DIE &Die)
virtual void recordTargetSourceLine(const DebugLoc &DL, unsigned Flags)
Target-specific source line recording.
bool isLexicalScopeDIENull(LexicalScope *Scope)
A helper function to check whether the DIE for a given Scope is going to be null.
void addDwarfTypeUnitType(DwarfCompileUnit &CU, StringRef Identifier, DIE &Die, const DICompositeType *CTy)
Add a DIE to the set of types that we're going to pull into type units.
DwarfFile InfoHolder
Holder for the file specific debug information.
Definition DwarfDebug.h:710
void endModule() override
Emit all Dwarf sections that should come after the content.
void addAccelType(const DwarfUnit &Unit, const DICompileUnit::DebugNameTableKind NameTableKind, StringRef Name, const DIE &Die, char Flags)
void beginCodeAlignment(const MachineBasicBlock &MBB) override
Process beginning of code alignment.
DwarfDebug(AsmPrinter *A)
void beginFunctionImpl(const MachineFunction *MF) override
Gather pre-function debug information.
AccelTableKind getAccelTableKind() const
Returns what kind (if any) of accelerator tables to emit.
Definition DwarfDebug.h:865
static uint64_t makeTypeSignature(StringRef Identifier)
Perform an MD5 checksum of Identifier and return the lower 64 bits.
Base class containing the logic for constructing DWARF expressions independently of whether they are ...
void setLocation(const MachineLocation &Loc, const DIExpression *DIExpr)
Set the location (Loc) and DIExpression (DIExpr) to describe.
virtual void disableTemporaryBuffer()=0
Disable emission to the temporary buffer.
virtual unsigned getTemporaryBufferSize()=0
Return the emitted size, in number of bytes, for the data stored in the temporary buffer.
void finalize()
This needs to be called last to commit any pending changes.
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...
void setMemoryLocationKind()
Lock this down to become a memory location description.
std::optional< uint8_t > TagOffset
void addBooleanConstant(int64_t Value)
Emit a boolean constant.
void addConstantFP(const APFloat &Value, const AsmPrinter &AP)
Emit an floating point constant.
bool addMachineRegExpression(const TargetRegisterInfo &TRI, DIExpressionCursor &Expr, llvm::Register MachineReg, unsigned FragmentOffsetInBits=0)
Emit a machine register location.
void addUnsignedConstant(uint64_t Value)
Emit an unsigned constant.
void addExpression(DIExpressionCursor &&Expr)
Emit all remaining operations in the DIExpressionCursor.
void addImplicitValue(const APInt &Value, const AsmPrinter &AP)
Emit an implicit value.
void addSignedConstant(int64_t Value)
Emit a signed constant.
virtual void commitTemporaryBuffer()=0
Commit the data stored in the temporary buffer to the main output.
void addWasmLocation(unsigned Index, uint64_t Offset)
Emit location information expressed via WebAssembly location + offset The Index is an identifier for ...
virtual void enableTemporaryBuffer()=0
Start emitting data to the temporary buffer.
void beginEntryValueExpression(DIExpressionCursor &ExprCursor)
Begin emission of an entry value dwarf operation.
void setRnglistsTableBaseSym(MCSymbol *Sym)
Definition DwarfFile.h:160
void emitUnits(bool UseOffsets)
Emit all of the units to the section listed with the given abbreviation section.
Definition DwarfFile.cpp:29
const SmallVectorImpl< RangeSpanList > & getRangeLists() const
getRangeLists - Get the vector of range lists.
Definition DwarfFile.h:119
MCSymbol * getStringOffsetsStartSym() const
Definition DwarfFile.h:156
MCSymbol * getRnglistsTableBaseSym() const
Definition DwarfFile.h:159
DwarfStringPool & getStringPool()
Returns the string pool.
Definition DwarfFile.h:154
void emitAbbrevs(MCSection *)
Emit a set of abbreviations to the specific section.
Definition DwarfFile.cpp:97
void emitStrings(MCSection *StrSection, MCSection *OffsetSection=nullptr, bool UseRelativeOffsets=false)
Emit all of the strings to the section given.
DwarfStringPoolEntryRef: Dwarf string pool entry reference.
LLVM_ABI_FOR_TEST EntryRef getEntry(AsmPrinter &Asm, StringRef Str)
Get a reference to an entry in the string pool.
LLVM_ABI_FOR_TEST void emitStringOffsetsTableHeader(AsmPrinter &Asm, MCSection *OffsetSection, MCSymbol *StartSym)
void setTypeSignature(uint64_t Signature)
Definition DwarfUnit.h:434
void setType(const DIE *Ty)
Definition DwarfUnit.h:437
This dwarf writer support class manages information associated with a source file.
Definition DwarfUnit.h:36
void addStringOffsetsStart()
Add the DW_AT_str_offsets_base attribute to the unit DIE.
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.
DIE * createTypeDIE(const DIScope *Context, DIE &ContextDIE, const DIType *Ty)
Creates type DIE with specific context.
const DICompileUnit * getCUNode() const
Definition DwarfUnit.h:112
void addFlag(DIE &Die, dwarf::Attribute Attribute)
Add a flag that is true to the DIE.
unsigned getUniqueID() const
Gets Unique ID for this unit.
Definition DwarfUnit.h:102
DISubprogram * getSubprogram() const
Get the attached subprogram.
LLVMContext & getContext() const
getContext - Return a reference to the LLVMContext associated with this function.
Definition Function.cpp:353
static StringRef dropLLVMManglingEscape(StringRef Name)
If the given string begins with the GlobalValue name mangling escape character '\1',...
bool analyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB, MachineBasicBlock *&FBB, SmallVectorImpl< MachineOperand > &Cond, bool AllowModify) const override
Analyze the branching code at the end of MBB, returning true if it cannot be understood (e....
bool isTailCall(const MachineInstr &MI) const override
Record instruction ordering so we can query their relative positions within a function.
This class is used to track scope information.
SmallVectorImpl< InsnRange > & getRanges()
const DILocalScope * getScopeNode() const
This class provides interface to collect and use lexical scoping information from machine instruction...
LLVM_ABI LexicalScope * findLexicalScope(const DILocation *DL)
Find lexical scope, either regular or inlined, for the given DebugLoc.
LexicalScope * findAbstractScope(const DILocalScope *N)
Find an abstract scope or return null.
Single(DbgValueLoc ValueLoc)
unsigned getCodePointerSize() const
Get the code pointer size in bytes.
Definition MCAsmInfo.h:452
static LLVM_ABI void make(MCStreamer *MCOS, MCSection *Section)
Definition MCDwarf.cpp:91
MCSection * getDwarfLoclistsSection() const
MCSection * getDwarfRangesSection() const
MCSection * getDwarfMacroSection() const
MCSection * getDwarfMacinfoDWOSection() const
MCSection * getDwarfMacinfoSection() const
MCSection * getDwarfMacroDWOSection() const
static constexpr unsigned NoRegister
Definition MCRegister.h:60
Instances of this class represent a uniqued identifier for a section in the current translation unit.
Definition MCSection.h:573
MCSymbol * getBeginSymbol()
Definition MCSection.h:646
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
Definition MCSymbol.h:42
uint32_t getIndex() const
Get the (implementation defined) index.
Definition MCSymbol.h:280
MCSection & getSection() const
Get the section associated with a defined, non-absolute symbol.
Definition MCSymbol.h:251
LLVM_ABI void update(ArrayRef< uint8_t > Data)
Updates the hash for the byte stream provided.
Definition MD5.cpp:188
LLVM_ABI void final(MD5Result &Result)
Finishes off the hash and puts the result in result.
Definition MD5.cpp:233
Metadata node.
Definition Metadata.h:1069
static MDTuple * get(LLVMContext &Context, ArrayRef< Metadata * > MDs)
Definition Metadata.h:1554
MBBSectionID getSectionID() const
Returns the section ID of this basic block.
iterator_range< succ_iterator > successors()
reverse_iterator rbegin()
iterator_range< pred_iterator > predecessors()
MachineInstrBundleIterator< const MachineInstr, true > const_reverse_iterator
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
const CallSiteInfoMap & getCallSitesInfo() const
Function & getFunction()
Return the LLVM function that this machine code represents.
Representation of each machine instruction.
const MachineBasicBlock * getParent() const
bool isCall(QueryType Type=AnyInBundle) const
bool isBundle() const
unsigned getNumOperands() const
Retuns the total number of operands.
bool hasDelaySlot(QueryType Type=AnyInBundle) const
Returns true if the specified instruction has a delay slot which must be filled by the code generator...
mop_range uses()
Returns all operands which may be register uses.
LLVM_ABI const MachineFunction * getMF() const
Return the function that contains the basic block that this instruction belongs to.
const DebugLoc & getDebugLoc() const
Returns the debug location id of this MachineInstr.
bool isDebugValue() const
unsigned getReg() const
MachineOperand class - Representation of each machine instruction operand.
const GlobalValue * getGlobal() const
bool isReg() const
isReg - Tests if this is a MO_Register operand.
bool isGlobal() const
isGlobal - Tests if this is a MO_GlobalAddress operand.
Register getReg() const
getReg - Returns the register number.
This class implements a map that also provides access to all stored values in a deterministic order.
Definition MapVector.h:38
iterator begin()
Definition MapVector.h:67
iterator end()
Definition MapVector.h:69
bool empty() const
Definition MapVector.h:79
std::pair< iterator, bool > insert(const std::pair< KeyT, ValueT > &KV)
Definition MapVector.h:126
VectorType::iterator erase(typename VectorType::iterator Iterator)
Remove the element given by Iterator.
Definition MapVector.h:210
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
Wrapper class representing virtual and physical registers.
Definition Register.h:20
constexpr bool isPhysical() const
Return true if the specified register number is in the physical register namespace.
Definition Register.h:83
bool empty() const
Determine if the SetVector is empty or not.
Definition SetVector.h:100
A SetVector that performs no allocations if smaller than a certain size.
Definition SetVector.h:339
SmallSet - This maintains a set of unique values, optimizing for the case when the set is small (less...
Definition SmallSet.h:134
void insert_range(Range &&R)
Definition SmallSet.h:196
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 assign(size_type NumElts, ValueParamT Elt)
reference emplace_back(ArgTypes &&... Args)
iterator erase(const_iterator CI)
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringMap - This is an unconventional map that is specialized for handling keys that are "strings",...
Definition StringMap.h:128
Represent a constant reference to a string, i.e.
Definition StringRef.h:56
constexpr bool empty() const
Check if the string is empty.
Definition StringRef.h:141
TargetInstrInfo - Interface to description of machine instruction set.
const Triple & getTargetTriple() const
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
virtual const TargetInstrInfo * getInstrInfo() const
virtual const TargetRegisterInfo * getRegisterInfo() const =0
Return the target's register information.
virtual const TargetLowering * getTargetLowering() const
Triple - Helper class for working with autoconf configuration names.
Definition Triple.h:47
bool isWasm() const
Tests whether the target is wasm (32- and 64-bit).
Definition Triple.h:1120
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
Definition Twine.h:82
LLVM Value Representation.
Definition Value.h:75
LLVM_ABI StringRef getName() const
Return a constant reference to the value's name.
Definition Value.cpp:319
std::pair< iterator, bool > insert(const ValueT &V)
Definition DenseSet.h:209
void insert_range(Range &&R)
Definition DenseSet.h:235
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:187
reverse_self_iterator getReverseIterator()
Definition ilist_node.h:126
self_iterator getIterator()
Definition ilist_node.h:123
A raw_ostream that writes to an SmallVector or SmallString.
bool tuneForSCE() const
Definition DwarfDebug.h:981
bool tuneForDBX() const
Definition DwarfDebug.h:982
bool tuneForGDB() const
Definition DwarfDebug.h:979
bool tuneForLLDB() const
Definition DwarfDebug.h:980
LLVM_ABI StringRef RangeListEncodingString(unsigned Encoding)
Definition Dwarf.cpp:764
LLVM_ABI StringRef GDBIndexEntryLinkageString(GDBIndexEntryLinkage Linkage)
Definition Dwarf.cpp:879
LLVM_ABI StringRef MacroString(unsigned Encoding)
Definition Dwarf.cpp:736
LLVM_ABI StringRef LocListEncodingString(unsigned Encoding)
Definition Dwarf.cpp:775
LLVM_ABI StringRef GnuMacroString(unsigned Encoding)
Definition Dwarf.cpp:747
LLVM_ABI StringRef MacinfoString(unsigned Encoding)
Definition Dwarf.cpp:707
LLVM_ABI StringRef OperationEncodingString(unsigned Encoding)
Definition Dwarf.cpp:138
LLVM_ABI StringRef GDBIndexEntryKindString(GDBIndexEntryKind Kind)
Definition Dwarf.cpp:856
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr char Align[]
Key for Kernel::Arg::Metadata::mAlign.
@ Entry
Definition COFF.h:862
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
Definition CallingConv.h:24
ValuesClass values(OptsTy... Options)
Helper to build a ValuesClass by forwarding a variable number of arguments as an initializer list to ...
initializer< Ty > init(const Ty &Val)
Attribute
Attributes.
Definition Dwarf.h:125
@ DWARF64
Definition Dwarf.h:93
@ DWARF32
Definition Dwarf.h:93
@ DW_MACINFO_start_file
Definition Dwarf.h:825
@ DW_MACINFO_end_file
Definition Dwarf.h:826
@ DW_MACINFO_define
Definition Dwarf.h:823
@ GIEK_NONE
Definition Dwarf.h:978
@ GIEK_TYPE
Definition Dwarf.h:979
@ GIEK_FUNCTION
Definition Dwarf.h:981
@ GIEK_VARIABLE
Definition Dwarf.h:980
bool isCPlusPlus(SourceLanguage S)
Definition Dwarf.h:518
@ DW_ARANGES_VERSION
Section version number for .debug_aranges.
Definition Dwarf.h:66
@ DW_PUBNAMES_VERSION
Section version number for .debug_pubnames.
Definition Dwarf.h:65
@ DWARF_VERSION
Other constants.
Definition Dwarf.h:63
GDBIndexEntryLinkage
Definition Dwarf.h:988
@ GIEL_EXTERNAL
Definition Dwarf.h:988
@ GIEL_STATIC
Definition Dwarf.h:988
LLVM_ABI MCSymbol * emitListsTableHeaderStart(MCStreamer &S)
Definition MCDwarf.cpp:44
NodeAddr< InstrNode * > Instr
Definition RDFGraph.h:389
bool empty() const
Definition BasicBlock.h:101
This is an optimization pass for GlobalISel generic memory operations.
@ Offset
Definition DWP.cpp:573
@ Length
Definition DWP.cpp:573
bool operator<(int64_t V1, const APSInt &V2)
Definition APSInt.h:360
MachineBasicBlock::instr_iterator getBundleStart(MachineBasicBlock::instr_iterator I)
Returns an iterator to the first instruction in the bundle containing I.
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1739
std::string fromHex(StringRef Input)
Convert hexadecimal string Input to its binary representation. The return string is half the size of ...
RelativeUniformCounterPtr Values
Definition InstrProf.h:91
auto enumerate(FirstRange &&First, RestRanges &&...Rest)
Given two or more input ranges, returns a new range whose values are tuples (A, B,...
Definition STLExtras.h:2554
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:643
LLVM_ABI bool isRangeRelaxable(const MCSymbol *Begin, const MCSymbol *End)
Definition MCSymbol.cpp:94
constexpr bool isUIntN(unsigned N, uint64_t x)
Checks if an unsigned integer fits into the given (dynamic) bit width.
Definition MathExtras.h:243
auto cast_or_null(const Y &Val)
Definition Casting.h:714
auto unique(Range &&R, Predicate P)
Definition STLExtras.h:2134
bool isa_and_nonnull(const Y &Val)
Definition Casting.h:676
Op::Description Desc
SmallVector< DbgCallSiteParam, 4 > ParamSet
Collection used for storing debug call site parameters.
Definition DwarfDebug.h:333
RelativeUniformCounterPtr ValuesPtrExpr VTableAddr Value
Definition InstrProf.h:143
auto dyn_cast_or_null(const Y &Val)
Definition Casting.h:753
void erase(Container &C, ValueType V)
Wrapper function to remove a value from a container:
Definition STLExtras.h:2200
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
void sort(IteratorTy Start, IteratorTy End)
Definition STLExtras.h:1636
AccelTableKind
The kind of accelerator tables we should emit.
Definition DwarfDebug.h:344
@ Default
Platform default.
Definition DwarfDebug.h:345
@ Apple
.apple_names, .apple_namespaces, .apple_types, .apple_objc.
Definition DwarfDebug.h:347
@ Dwarf
DWARF v5 .debug_names.
Definition DwarfDebug.h:348
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
Definition Debug.cpp:209
bool none_of(R &&Range, UnaryPredicate P)
Provide wrappers to std::none_of which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1753
LLVM_ABI void report_fatal_error(Error Err, bool gen_crash_diag=true)
Definition Error.cpp:163
MachineBasicBlock::instr_iterator getBundleEnd(MachineBasicBlock::instr_iterator I)
Returns an iterator pointing beyond the bundle containing I.
bool is_sorted(R &&Range, Compare C)
Wrapper function around std::is_sorted to check if elements in a range R are sorted with respect to a...
Definition STLExtras.h:1970
class LLVM_GSL_OWNER SmallVector
Forward declaration of SmallVector so that calculateSmallVectorDefaultInlinedElements can reference s...
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
uint64_t offsetToAlignment(uint64_t Value, Align Alignment)
Returns the offset to the next integer (mod 2**64) that is greater than or equal to Value and is a mu...
Definition Alignment.h:186
@ Ref
The access may reference the value stored in memory.
Definition ModRef.h:32
auto remove_if(R &&Range, UnaryPredicate P)
Provide wrappers to std::remove_if which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1784
void emitAppleAccelTable(AsmPrinter *Asm, AccelTable< DataT > &Contents, StringRef Prefix, const MCSymbol *SecBegin)
Emit an Apple Accelerator Table consisting of entries in the specified AccelTable.
Definition AccelTable.h:446
DWARFExpression::Operation Op
OutputIt copy(R &&Range, OutputIt Out)
Definition STLExtras.h:1885
LLVM_ABI void emitDWARF5AccelTable(AsmPrinter *Asm, DWARF5AccelTable &Contents, const DwarfDebug &DD, ArrayRef< std::unique_ptr< DwarfCompileUnit > > CUs)
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:559
void erase_if(Container &C, UnaryPredicate P)
Provide a container algorithm similar to C++ Library Fundamentals v2's erase_if which is equivalent t...
Definition STLExtras.h:2192
constexpr bool isIntN(unsigned N, int64_t x)
Checks if an signed integer fits into the given (dynamic) bit width.
Definition MathExtras.h:248
DebuggerKind
Identify a debugger for "tuning" the debug info.
@ SCE
Tune debug info for SCE targets (e.g. PS4).
@ DBX
Tune debug info for dbx.
@ Default
No specific tuning requested.
@ GDB
Tune debug info for gdb.
@ LLDB
Tune debug info for lldb.
@ Enable
Enable colors.
Definition WithColor.h:47
@ Disable
Disable colors.
Definition WithColor.h:49
Implement std::hash so that hash_code can be used in STL containers.
Definition BitVector.h:860
#define N
const MCSymbol * Start
const MCSymbol * End
Represents a parameter whose call site value can be described by applying a debug expression to a reg...
uint64_t ParamReg
The described parameter register.
const DIExpression * Expr
Debug expression that has been built up when walking through the instruction chain that produces the ...
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition Alignment.h:39
A pair of GlobalVariable and DIExpression.
Represents an entry-value location, or a fragment of one.
Definition DwarfDebug.h:121
Proxy for one MMI entry.
Definition DwarfDebug.h:112
void addFrameIndexExpr(const DIExpression *Expr, int FI)
std::set< FrameIndexExpr > FrameIndexExprs
Definition DwarfDebug.h:161
const std::set< FrameIndexExpr > & getFrameIndexExprs() const
Get the FI entries, sorted by fragment offset.
A MapVector that performs no allocations if smaller than a certain size.
Definition MapVector.h:342
Helper used to pair up a symbol and its DWARF compile unit.
Definition DwarfDebug.h:336
const MCSymbol * Sym
Definition DwarfDebug.h:339
DwarfCompileUnit * CU
Definition DwarfDebug.h:340
This struct describes target specific location.
Describes an entry of the various gnu_pub* debug sections.
Definition Dwarf.h:1197