47 "add-linkage-names-to-declaration-call-origins",
cl::Hidden,
48 cl::desc(
"Add DW_AT_linkage_name to function declaration DIEs "
49 "referenced by DW_AT_call_origin attributes. Enabled by default "
50 "for -gsce debugger tuning."));
53 "emit-func-debug-line-table-offsets",
cl::Hidden,
54 cl::desc(
"Include line table offset in function's debug info and emit end "
55 "sequence after each function's line data."),
73 return dwarf::DW_TAG_skeleton_unit;
75 return dwarf::DW_TAG_compile_unit;
83 MacroLabelBegin =
Asm->createTempSymbol(
"cu_macro_begin");
90 if ((Skeleton || !
DD->useSplitDwarf()) && Label)
94 if ((!
DD->useSplitDwarf() || !Skeleton) &&
DD->getDwarfVersion() < 5)
97 bool UseAddrOffsetFormOrExpressions =
98 DD->useAddrOffsetForm() ||
DD->useAddrOffsetExpressions();
101 if (Label->isInSection() && UseAddrOffsetFormOrExpressions)
102 Base =
DD->getSectionLabel(&Label->getSection());
105 unsigned idx =
DD->getAddressPool().getIndex(Label);
107 DD->getDwarfVersion() >= 5 ? dwarf::DW_FORM_addrx
108 : dwarf::DW_FORM_GNU_addr_index,
115 assert(
DD->getDwarfVersion() >= 5 &&
116 "Addr+offset expressions are only valuable when using debug_addr (to "
117 "reduce relocations) available in DWARFv5 or higher");
118 if (
DD->useAddrOffsetExpressions()) {
125 DD->getAddressPool().getIndex(
Base), Label,
Base));
143 unsigned CUID =
Asm->OutStreamer->hasRawTextSupport() ? 0 :
getUniqueID();
145 return Asm->OutStreamer->emitDwarfFileDirective(0,
"",
"", std::nullopt,
148 if (LastFile != File) {
150 LastFileID =
Asm->OutStreamer->emitDwarfFileDirective(
151 0, File->getDirectory(), File->getFilename(),
DD->getMD5AsBytes(File),
152 File->getSource(), CUID);
177 assert(SDMDecl->isStaticMember() &&
"Expected static member decl");
181 addDIEEntry(*VariableDIE, dwarf::DW_AT_specification, *VariableSpecDIE);
184 if (GTy != SDMDecl->getBaseType())
190 if (!DisplayName.
empty())
197 addFlag(*VariableDIE, dwarf::DW_AT_external);
204 addFlag(*VariableDIE, dwarf::DW_AT_declaration);
211 addUInt(*VariableDIE, dwarf::DW_AT_alignment, dwarf::DW_FORM_udata,
225 bool addToAccelTable =
false;
227 std::optional<unsigned> TargetAddrSpace;
228 std::unique_ptr<DIEDwarfExpression> DwarfExpr;
230 for (
const auto &GE : GlobalExprs) {
239 addToAccelTable =
true;
258 !
Asm->getObjFileLowering().supportDebugThreadLocalLocation())
262 addToAccelTable =
true;
264 DwarfExpr = std::make_unique<DIEDwarfExpression>(*
Asm, *
this, *
Loc);
268 Expr =
DD->adjustExpressionForTarget(Expr, TargetAddrSpace);
269 DwarfExpr->addFragmentOffset(Expr);
276 auto GetPointerSizedFormAndOp = [
this]() {
277 unsigned PointerSize =
Asm->MAI->getCodePointerSize();
278 assert((PointerSize == 4 || PointerSize == 8) &&
279 "Add support for other sizes if necessary");
284 return PointerSize == 4
285 ? FormAndOp{dwarf::DW_FORM_data4, dwarf::DW_OP_const4u}
286 : FormAndOp{dwarf::DW_FORM_data8, dwarf::DW_OP_const8u};
288 if (
Global->isThreadLocal()) {
289 if (
Asm->TM.getTargetTriple().isWasm()) {
295 addWasmRelocBaseGlobal(
Loc,
"__tls_base", 1);
297 addUInt(*
Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_plus);
298 }
else if (
Asm->TM.useEmulatedTLS()) {
303 if (!
DD->useSplitDwarf()) {
304 auto FormAndOp = GetPointerSizedFormAndOp();
306 addUInt(*
Loc, dwarf::DW_FORM_data1, FormAndOp.Op);
310 Asm->getObjFileLowering().getDebugThreadLocalSymbol(Sym));
312 addUInt(*
Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_GNU_const_index);
314 DD->getAddressPool().getIndex(Sym,
true));
318 DD->useGNUTLSOpcode() ? dwarf::DW_OP_GNU_push_tls_address
319 : dwarf::DW_OP_form_tls_address);
321 }
else if (
Asm->TM.getTargetTriple().isWasm() &&
326 addWasmRelocBaseGlobal(
Loc,
"__memory_base", 1);
328 addUInt(*
Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_plus);
331 !
Asm->getObjFileLowering()
334 auto FormAndOp = GetPointerSizedFormAndOp();
336 addUInt(*
Loc, dwarf::DW_FORM_data1, FormAndOp.Op);
339 Asm->getObjFileLowering().getIndirectSymViaRWPI(Sym));
341 Register BaseReg =
Asm->getObjFileLowering().getStaticBase();
342 unsigned DwarfBaseReg =
343 Asm->TM.getMCRegisterInfo()->getDwarfRegNum(BaseReg,
false);
344 addUInt(*
Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_breg0 + DwarfBaseReg);
348 addUInt(*
Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_plus);
359 if (DwarfExpr->isUnknownLocation())
360 DwarfExpr->setMemoryLocationKind();
361 DwarfExpr->addExpression(Expr);
363 DD->addTargetVariableAttributes(*
this, *VariableDIE, TargetAddrSpace,
367 addBlock(*VariableDIE, dwarf::DW_AT_location, DwarfExpr->finalize());
369 if (
DD->useAllLinkageNames())
372 if (addToAccelTable) {
379 DD->useAllLinkageNames())
393 addString(NDie, dwarf::DW_AT_name, Name);
403 DD->insertSectionLabel(
Range.Begin);
405 auto *PrevCU =
DD->getPrevCU();
406 bool SameAsPrevCU =
this == PrevCU;
412 if (CURanges.empty() || !SameAsPrevCU ||
413 (&CURanges.back().End->getSection() !=
414 &
Range.End->getSection())) {
417 DD->terminateLineTable(PrevCU);
418 CURanges.push_back(
Range);
422 CURanges.back().End =
Range.End;
426 if (
CUNode->isDebugDirectivesOnly())
430 if (
DD->useSectionsAsReferences()) {
454 assert(Begin &&
"Begin label should not be null!");
455 assert(End &&
"End label should not be null!");
460 if (
DD->getDwarfVersion() >= 4 &&
475 const unsigned TI_GLOBAL_RELOC = 3;
487 addUInt(*
Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_WASM_location);
488 addSInt(*
Loc, dwarf::DW_FORM_sdata, TI_GLOBAL_RELOC);
498 addUInt(*Loc, dwarf::DW_FORM_data4, GlobalIndex);
512 for (
const auto &R :
Asm->MBBSectionRanges)
513 BB_List.
push_back({R.second.BeginLabel, R.second.EndLabel});
517 if (
DD->useAppleExtensionAttributes() &&
518 !
DD->getCurrentFunction()->getTarget().Options.DisableFramePointerElim(
519 *
DD->getCurrentFunction()))
520 addFlag(*SPDie, dwarf::DW_AT_APPLE_omit_frame_ptr);
524 *SPDie, dwarf::DW_AT_LLVM_stmt_sequence, LineTableSym,
525 Asm->getObjFileLowering().getDwarfLineSection()->getBeginSymbol());
533 switch (FrameBase.
Kind) {
537 addAddress(*SPDie, dwarf::DW_AT_frame_base, Location);
543 addUInt(*
Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_call_frame_cfa);
545 addUInt(*
Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_consts);
547 addUInt(*
Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_plus);
554 const unsigned TI_GLOBAL_RELOC = 3;
560 addWasmRelocBaseGlobal(
Loc,
"__stack_pointer",
562 addUInt(*
Loc, dwarf::DW_FORM_data1, dwarf::DW_OP_stack_value);
580 DD->addSubprogramNames(*
this,
CUNode->getNameTableKind(), SP, *SPDie);
587 DIE &ParentScopeDIE) {
588 if (!Scope || !Scope->getScopeNode())
591 auto *DS = Scope->getScopeNode();
594 "Only handle inlined subprograms here, use "
595 "constructSubprogramScopeDIE for non-inlined "
601 assert(ScopeDIE &&
"Scope DIE should not be null.");
607 if (
DD->isLexicalScopeDIENull(Scope))
612 assert(ScopeDIE &&
"Scope DIE should not be null.");
620 HasRangeLists =
true;
624 (
DD->getDwarfVersion() < 5 && Skeleton ? Skeleton->DU :
DU)
625 ->addRange(*(Skeleton ? Skeleton :
this), std::move(
Range));
627 uint32_t Index = IndexAndList.first;
628 auto &
List = *IndexAndList.second;
635 if (
DD->getDwarfVersion() >= 5)
636 addUInt(ScopeDIE, dwarf::DW_AT_ranges, dwarf::DW_FORM_rnglistx, Index);
653 if (!
DD->useRangesSection() ||
654 (Ranges.size() == 1 &&
655 (!
DD->alwaysUseRanges(*
this) ||
656 DD->getSectionLabel(&Ranges.front().Begin->getSection()) ==
657 Ranges.front().Begin))) {
668 List.reserve(Ranges.size());
670 auto *BeginLabel =
DD->getLabelBeforeInsn(R.first);
671 auto *
EndLabel =
DD->getLabelAfterInsn(R.second);
673 const auto *BeginMBB = R.first->getParent();
674 const auto *EndMBB = R.second->getParent();
676 const auto *
MBB = BeginMBB;
684 if (
MBB->sameSection(EndMBB) ||
MBB->isEndSection()) {
685 auto MBBSectionRange =
Asm->MBBSectionRanges[
MBB->getSectionID()];
687 {
MBB->sameSection(BeginMBB) ? BeginLabel
688 : MBBSectionRange.BeginLabel,
689 MBB->sameSection(EndMBB) ?
EndLabel : MBBSectionRange.EndLabel});
691 if (
MBB->sameSection(EndMBB))
700 DIE &ParentScopeDIE) {
701 assert(Scope->getScopeNode());
702 auto *DS = Scope->getScopeNode();
706 DIE *OriginDIE = getAbstractScopeDIEs()[InlinedSP];
707 assert(OriginDIE &&
"Unable to find original DIE for an inlined subprogram.");
711 addDIEEntry(*ScopeDIE, dwarf::DW_AT_abstract_origin, *OriginDIE);
717 addUInt(*ScopeDIE, dwarf::DW_AT_call_file, std::nullopt,
719 addUInt(*ScopeDIE, dwarf::DW_AT_call_line, std::nullopt, IA->getLine());
721 addUInt(*ScopeDIE, dwarf::DW_AT_call_column, std::nullopt, IA->getColumn());
722 if (IA->getDiscriminator() &&
DD->getDwarfVersion() >= 4)
723 addUInt(*ScopeDIE, dwarf::DW_AT_GNU_discriminator, std::nullopt,
724 IA->getDiscriminator());
728 DD->addSubprogramNames(*
this,
CUNode->getNameTableKind(), InlinedSP,
735 DIE &ParentScopeDIE) {
736 if (
DD->isLexicalScopeDIENull(Scope))
738 const auto *DS = Scope->getScopeNode();
743 if (Scope->isAbstractScope()) {
745 "Abstract DIE for this scope exists!");
746 getAbstractScopeDIEs()[DS] = ScopeDIE;
749 if (!Scope->getInlinedAt()) {
750 assert(!LexicalBlockDIEs.count(DS) &&
751 "Concrete out-of-line DIE for this scope exists!");
752 LexicalBlockDIEs[DS] = ScopeDIE;
754 InlinedLocalScopeDIEs[DS].push_back(ScopeDIE);
772 applyConcreteDbgVariableAttributes(V, DV, *VariableDie);
779void DwarfCompileUnit::applyConcreteDbgVariableAttributes(
782 if (!Single.getExpr())
787 if (Entry->isLocation()) {
789 }
else if (Entry->isInt()) {
790 auto *Expr = Single.getExpr();
791 if (Expr && Expr->getNumElements()) {
795 DwarfExpr.addFragmentOffset(Expr);
796 DwarfExpr.addUnsignedConstant(Entry->getInt());
797 DwarfExpr.addExpression(Expr);
798 addBlock(VariableDie, dwarf::DW_AT_location, DwarfExpr.finalize());
799 if (DwarfExpr.TagOffset)
800 addUInt(VariableDie, dwarf::DW_AT_LLVM_tag_offset,
801 dwarf::DW_FORM_data1, *DwarfExpr.TagOffset);
804 }
else if (
Entry->isConstantFP()) {
806 }
else if (
Entry->isConstantInt()) {
808 }
else if (
Entry->isTargetIndexLocation()) {
810 DIEDwarfExpression DwarfExpr(*
Asm, *
this, *Loc);
814 addBlock(VariableDie, dwarf::DW_AT_location, DwarfExpr.finalize());
821 return Entry.isLocation() && !Entry.getLoc().getReg();
824 const DIExpression *Expr =
Single.getExpr();
825 assert(Expr &&
"Variadic Debug Value must have an Expression.");
827 DIEDwarfExpression DwarfExpr(*
Asm, *
this, *Loc);
828 DwarfExpr.addFragmentOffset(Expr);
829 DIExpressionCursor Cursor(Expr);
830 const TargetRegisterInfo &
TRI = *
Asm->MF->getSubtarget().getRegisterInfo();
832 auto AddEntry = [&](
const DbgValueLocEntry &
Entry,
833 DIExpressionCursor &Cursor) {
834 if (
Entry.isLocation()) {
835 if (!DwarfExpr.addMachineRegExpression(
TRI, Cursor,
836 Entry.getLoc().getReg()))
838 }
else if (
Entry.isInt()) {
840 DwarfExpr.addUnsignedConstant(
Entry.getInt());
841 }
else if (
Entry.isConstantFP()) {
846 APInt RawBytes =
Entry.getConstantFP()->getValueAPF().bitcastToAPInt();
850 }
else if (
Entry.isConstantInt()) {
851 APInt RawBytes =
Entry.getConstantInt()->getValue();
855 }
else if (
Entry.isTargetIndexLocation()) {
856 TargetIndexLocation Loc =
Entry.getTargetIndexLocation();
859 assert(
Asm->TM.getTargetTriple().isWasm());
860 DwarfExpr.addWasmLocation(Loc.
Index,
static_cast<uint64_t
>(Loc.
Offset));
867 if (!DwarfExpr.addExpression(
869 [&](
unsigned Idx, DIExpressionCursor &Cursor) ->
bool {
870 return AddEntry(DVal->getLocEntries()[Idx], Cursor);
875 addBlock(VariableDie, dwarf::DW_AT_location, DwarfExpr.finalize());
876 if (DwarfExpr.TagOffset)
877 addUInt(VariableDie, dwarf::DW_AT_LLVM_tag_offset, dwarf::DW_FORM_data1,
878 *DwarfExpr.TagOffset);
881void DwarfCompileUnit::applyConcreteDbgVariableAttributes(
887 addUInt(VariableDie, dwarf::DW_AT_LLVM_tag_offset, dwarf::DW_FORM_data1,
891void DwarfCompileUnit::applyConcreteDbgVariableAttributes(
const Loc::MMI &MMI,
894 std::optional<unsigned> TargetAddrSpace;
896 DIEDwarfExpression DwarfExpr(*
Asm, *
this, *Loc);
899 const DIExpression *Expr = Fragment.Expr;
900 const TargetFrameLowering *TFI =
Asm->MF->getSubtarget().getFrameLowering();
903 DwarfExpr.addFragmentOffset(Expr);
905 auto *
TRI =
Asm->MF->getSubtarget().getRegisterInfo();
906 SmallVector<uint64_t, 8>
Ops;
907 TRI->getOffsetOpcodes(Offset,
Ops);
909 Expr =
DD->adjustExpressionForTarget(Expr, TargetAddrSpace);
912 DIExpressionCursor Cursor(
Ops);
913 DwarfExpr.setMemoryLocationKind();
914 if (
const MCSymbol *FrameSymbol =
Asm->getFunctionFrameSymbol())
917 DwarfExpr.addMachineRegExpression(
918 *
Asm->MF->getSubtarget().getRegisterInfo(), Cursor, FrameReg);
919 DwarfExpr.addExpression(std::move(Cursor));
921 DD->addTargetVariableAttributes(*
this, VariableDie, TargetAddrSpace,
923 addBlock(VariableDie, dwarf::DW_AT_location, DwarfExpr.finalize());
924 if (DwarfExpr.TagOffset)
925 addUInt(VariableDie, dwarf::DW_AT_LLVM_tag_offset, dwarf::DW_FORM_data1,
926 *DwarfExpr.TagOffset);
929void DwarfCompileUnit::applyConcreteDbgVariableAttributes(
933 DIEDwarfExpression DwarfExpr(*
Asm, *
this, *Loc);
936 DwarfExpr.addFragmentOffset(&Expr);
938 DwarfExpr.beginEntryValueExpression(Cursor);
939 DwarfExpr.addMachineRegExpression(
940 *
Asm->MF->getSubtarget().getRegisterInfo(), Cursor,
Register);
941 DwarfExpr.addExpression(std::move(Cursor));
943 addBlock(VariableDie, dwarf::DW_AT_location, DwarfExpr.finalize());
946void DwarfCompileUnit::applyConcreteDbgVariableAttributes(
947 const std::monostate &,
const DbgVariable &DV,
DIE &VariableDie) {}
951 DIE *&ObjectPointer) {
962 DL.setDIE(*LabelDie);
964 if (Scope.isAbstractScope())
974 if (!Array || Array->getTag() != dwarf::DW_TAG_array_type)
976 if (
auto *DLVar = Array->getDataLocation())
977 Result.push_back(DLVar);
978 if (
auto *AsVar = Array->getAssociated())
979 Result.push_back(AsVar);
980 if (
auto *AlVar = Array->getAllocated())
981 Result.push_back(AlVar);
982 for (
auto *El : Array->getElements()) {
984 if (
auto Count = Subrange->getCount())
986 Result.push_back(Dependency);
987 if (
auto LB = Subrange->getLowerBound())
989 Result.push_back(Dependency);
990 if (
auto UB = Subrange->getUpperBound())
992 Result.push_back(Dependency);
993 if (
auto ST = Subrange->getStride())
995 Result.push_back(Dependency);
997 if (
auto Count = GenericSubrange->getCount())
999 Result.push_back(Dependency);
1000 if (
auto LB = GenericSubrange->getLowerBound())
1002 Result.push_back(Dependency);
1003 if (
auto UB = GenericSubrange->getUpperBound())
1005 Result.push_back(Dependency);
1006 if (
auto ST = GenericSubrange->getStride())
1008 Result.push_back(Dependency);
1029 DbgVar.
insert({Var->getVariable(), Var});
1034 while (!WorkList.
empty()) {
1035 auto Item = WorkList.
back();
1037 bool visitedAllDependencies = Item.getInt();
1043 if (Visited.
count(Var))
1047 if (visitedAllDependencies) {
1049 Result.push_back(Var);
1054 auto Res = Visiting.
insert(Var);
1056 assert(
false &&
"dependency cycle in local variables");
1080 assert(!Scope->getInlinedAt());
1081 assert(!Scope->isAbstractScope());
1086 addDIEEntry(ScopeDIE, dwarf::DW_AT_object_pointer, *ObjectPointer);
1090 DITypeArray FnArgs =
Sub->getType()->getTypeArray();
1095 if (FnArgs.size() > 1 && !FnArgs[FnArgs.size() - 1] &&
1105 DIE *ObjectPointer =
nullptr;
1108 auto Vars =
DU->getScopeVariables().lookup(Scope);
1109 for (
auto &DV : Vars.Args)
1118 for (
DbgLabel *
DL :
DU->getScopeLabels().lookup(Scope))
1125 auto &LocalDecls =
DD->getLocalDeclsForScope(Scope->getScopeNode());
1126 DeferredLocalDecls.insert_range(LocalDecls);
1130 auto skipLexicalScope = [
this](
LexicalScope *S) ->
bool {
1133 auto Vars =
DU->getScopeVariables().lookup(S);
1134 if (!Vars.Args.empty() || !Vars.Locals.empty())
1137 DD->getLocalDeclsForScope(S->getScopeNode()).empty();
1142 if (skipLexicalScope(LS))
1148 return ObjectPointer;
1153 if (
auto *AbsDef = getAbstractScopeDIEs().
lookup(SP))
1156 auto [ContextDIE, ContextCU] = getOrCreateAbstractSubprogramContextDIE(SP);
1157 return createAbstractSubprogramDIE(SP, ContextDIE, ContextCU);
1160DIE &DwarfCompileUnit::createAbstractSubprogramDIE(
1165 *ContextDIE,
nullptr);
1168 ContextCU->getAbstractScopeDIEs()[SP] = &AbsDef;
1171 ContextCU->
addSInt(AbsDef, dwarf::DW_AT_inline,
1173 : dwarf::DW_FORM_implicit_const,
1179std::pair<DIE *, DwarfCompileUnit *>
1180DwarfCompileUnit::getOrCreateAbstractSubprogramContextDIE(
1186 if (
auto *SPDecl = SP->getDeclaration())
1195 return std::make_pair(ContextDIE, ContextCU);
1203 if (!getFinalizedAbstractSubprograms().insert(SP).second)
1206 auto [ContextDIE, ContextCU] = getOrCreateAbstractSubprogramContextDIE(SP);
1207 DIE *AbsDef = getAbstractScopeDIEs().lookup(SP);
1209 AbsDef = &createAbstractSubprogramDIE(SP, ContextDIE, ContextCU);
1212 ContextCU->
addDIEEntry(*AbsDef, dwarf::DW_AT_object_pointer,
1217 return DD->getDwarfVersion() <= 4 && !
DD->tuneForLLDB();
1224 case dwarf::DW_TAG_call_site:
1225 return dwarf::DW_TAG_GNU_call_site;
1226 case dwarf::DW_TAG_call_site_parameter:
1227 return dwarf::DW_TAG_GNU_call_site_parameter;
1238 case dwarf::DW_AT_call_all_calls:
1239 return dwarf::DW_AT_GNU_all_call_sites;
1240 case dwarf::DW_AT_call_target:
1241 return dwarf::DW_AT_GNU_call_site_target;
1242 case dwarf::DW_AT_call_target_clobbered:
1243 return dwarf::DW_AT_GNU_call_site_target_clobbered;
1244 case dwarf::DW_AT_call_origin:
1245 return dwarf::DW_AT_abstract_origin;
1246 case dwarf::DW_AT_call_return_pc:
1247 return dwarf::DW_AT_low_pc;
1248 case dwarf::DW_AT_call_value:
1249 return dwarf::DW_AT_GNU_call_site_value;
1250 case dwarf::DW_AT_call_tail_call:
1251 return dwarf::DW_AT_GNU_tail_call;
1262 case dwarf::DW_OP_entry_value:
1263 return dwarf::DW_OP_GNU_entry_value;
1278 if (CallTarget.
getReg()) {
1285 TRI.isCalleeSavedPhysReg(CallTarget.
getReg(), *
Asm->MF)
1286 ? dwarf::DW_AT_call_target
1287 : dwarf::DW_AT_call_target_clobbered);
1295 }
else if (CalleeSP) {
1297 assert(CalleeDIE &&
"Could not create DIE for call site entry origin");
1331 assert(PCAddr &&
"Missing return PC information for a call");
1337 addType(CallSiteDIE, AllocSiteTy, dwarf::DW_AT_LLVM_alloc_type);
1344 for (
const auto &Param : Params) {
1345 unsigned Register = Param.getRegister();
1346 auto CallSiteDieParam =
1350 addAddress(*CallSiteDieParam, dwarf::DW_AT_location,
1362 CallSiteDIE.
addChild(CallSiteDieParam);
1371 auto *Entity =
Module->getEntity();
1380 if (
auto *AbsSPDie = getAbstractScopeDIEs().
lookup(SP))
1381 EntityDie = AbsSPDie;
1391 EntityDie =
getDIE(Entity);
1394 addDIEEntry(*IMDie, dwarf::DW_AT_import, *EntityDie);
1396 if (!Name.empty()) {
1397 addString(*IMDie, dwarf::DW_AT_name, Name);
1404 DD->addAccelNamespace(*
this,
CUNode->getNameTableKind(), Name, *IMDie);
1409 DINodeArray Elements =
Module->getElements();
1410 for (
const auto *Element : Elements) {
1428 assert(ContextDIE &&
"Empty scope for the imported entity!");
1437 if (
DIE *AbsSPDIE = getAbstractScopeDIEs().
lookup(SP)) {
1440 addDIEEntry(*
D, dwarf::DW_AT_abstract_origin, *AbsSPDIE);
1452 auto *Die = Entity->
getDIE();
1456 if (AbsEntity && AbsEntity->
getDIE()) {
1471 const auto *Sym = Label->getSymbol();
1478 if (
StringRef Name = Label->getName(); !Name.empty())
1484 if (
auto *AbsLSDie = getAbstractScopeDIEs().
lookup(LS))
1485 addDIEEntry(*ScopeDIE, dwarf::DW_AT_abstract_origin, *AbsLSDie);
1488 for (
auto [LScope, ScopeDIE] : LexicalBlockDIEs)
1489 AttachAO(LScope, ScopeDIE);
1490 for (
auto &[LScope, ScopeDIEs] : InlinedLocalScopeDIEs)
1491 for (
auto *ScopeDIE : ScopeDIEs)
1492 AttachAO(LScope, ScopeDIE);
1496 auto &AbstractEntities = getAbstractEntities();
1497 auto I = AbstractEntities.find(
Node);
1498 if (
I != AbstractEntities.end())
1499 return I->second.get();
1505 assert(Scope && Scope->isAbstractScope());
1506 auto &Entity = getAbstractEntities()[
Node];
1512 Entity = std::make_unique<DbgLabel>(
1520 if (!Skeleton && !
DD->useSectionsAsReferences()) {
1526 :
DD->useSplitDwarf() ? dwarf::DW_UT_skeleton
1527 : dwarf::DW_UT_compile;
1529 if (
DD->getDwarfVersion() >= 5 && UT != dwarf::DW_UT_compile)
1534 switch (
CUNode->getNameTableKind()) {
1545 !
CUNode->isDebugDirectivesOnly() &&
1547 DD->getDwarfVersion() < 5;
1558 GlobalNames[FullName] = &Die;
1570 GlobalNames.insert(std::make_pair(std::move(FullName), &
getUnitDie()));
1579 GlobalTypes[FullName] = &Die;
1591 GlobalTypes.insert(std::make_pair(std::move(FullName), &
getUnitDie()));
1596 auto *Single = std::get_if<Loc::Single>(&DV);
1597 if (Single && Single->getExpr())
1600 addAddress(Die, dwarf::DW_AT_location, Location);
1608 if (Location.isIndirect())
1609 DwarfExpr.setMemoryLocationKind();
1613 if (!DwarfExpr.addMachineRegExpression(
TRI, Cursor, Location.getReg()))
1615 DwarfExpr.addExpression(std::move(Cursor));
1620 if (DwarfExpr.TagOffset)
1621 addUInt(Die, dwarf::DW_AT_LLVM_tag_offset, dwarf::DW_FORM_data1,
1622 *DwarfExpr.TagOffset);
1628 addLocationWithExpr(Die,
Attribute, Location, {});
1636 assert(Location.isIndirect() &&
"Memory loc should be indirect");
1668 addUInt(Die, dwarf::DW_AT_LLVM_tag_offset, dwarf::DW_FORM_data1,
1676 ? dwarf::DW_FORM_loclistx
1677 :
DD->getDwarfSectionOffsetForm();
1685 addString(VariableDie, dwarf::DW_AT_name, Name);
1688 if (
uint32_t AlignInBytes = DIVar->getAlignInBytes())
1689 addUInt(VariableDie, dwarf::DW_AT_alignment, dwarf::DW_FORM_udata,
1697 addFlag(VariableDie, dwarf::DW_AT_artificial);
1704 addString(LabelDie, dwarf::DW_AT_name, Name);
1705 const auto *
DILabel = Label.getLabel();
1708 addFlag(LabelDie, dwarf::DW_AT_artificial);
1710 addUInt(LabelDie, dwarf::DW_AT_LLVM_coro_suspend_idx, std::nullopt,
1722 auto *SPDecl = SP->getDeclaration();
1723 auto *Context = SPDecl ? SPDecl->getScope() : SP->getScope();
1728bool DwarfCompileUnit::isDwoUnit()
const {
1738 (
DD->useSplitDwarf() && !Skeleton);
1747 MCSymbol *Label =
DD->getAddressPool().getLabel();
1749 DD->getDwarfVersion() >= 5 ? dwarf::DW_AT_addr_base
1750 : dwarf::DW_AT_GNU_addr_base,
1771 addUInt(Die, dwarf::DW_AT_encoding, dwarf::DW_FORM_data1, Btr.Encoding);
1778 addUInt(Die, dwarf::DW_AT_byte_size, std::nullopt,
1786 bool isAbstract = getAbstractScopeDIEs().count(LB->
getSubprogram());
1788 auto &DIEs = getAbstractScopeDIEs();
1789 if (
auto It = DIEs.find(LB); It != DIEs.end())
1792 assert(!isAbstract &&
"Missed lexical block DIE in abstract tree!");
1795 if (
auto It = LexicalBlockDIEs.find(LB); It != LexicalBlockDIEs.end())
1807 Context = LFScope->getNonLexicalBlockFileScope();
1813 const auto &DIEs = getAbstractScopeDIEs();
1814 if (
auto It = DIEs.find(SPScope); It != DIEs.end())
1823 if (!
F && SP->isDefinition()) {
1824 F =
DD->getLexicalScopes().getFunction(SP);
1829 return &
DD->getOrCreateAbstractSubprogramCU(SP, *
this)
1830 .getOrCreateAbstractSubprogramDIE(SP);
1840 !CalleeSP.isDefinition() &&
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< StatepointGC > D("statepoint-example", "an example strategy for statepoint")
static SmallVector< DbgVariable *, 8 > sortLocalVars(SmallVectorImpl< DbgVariable * > &Input)
Sort local variables so that variables appearing inside of helper expressions come first.
static SmallVector< const DIVariable *, 2 > dependencies(DbgVariable *Var)
Return all DIVariables that appear in count: expressions.
static cl::opt< bool > EmitFuncLineTableOffsetsOption("emit-func-debug-line-table-offsets", cl::Hidden, cl::desc("Include line table offset in function's debug info and emit end " "sequence after each function's line data."), cl::init(false))
static bool AddLinkageNamesToDeclCallOriginsForTuning(const DwarfDebug *DD)
static dwarf::Tag GetCompileUnitType(UnitKind Kind, DwarfDebug *DW)
static cl::opt< cl::boolOrDefault > AddLinkageNamesToDeclCallOrigins("add-linkage-names-to-declaration-call-origins", cl::Hidden, cl::desc("Add DW_AT_linkage_name to function declaration DIEs " "referenced by DW_AT_call_origin attributes. Enabled by default " "for -gsce debugger tuning."))
Query value using AddLinkageNamesToDeclCallOriginsForTuning.
This file contains constants used for implementing Dwarf debug support.
static bool lookup(const GsymReader &GR, DataExtractor &Data, uint64_t &Offset, uint64_t BaseAddr, uint64_t Addr, SourceLocations &SrcLocs, llvm::Error &Err)
A Lookup helper functions.
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
Register const TargetRegisterInfo * TRI
Promote Memory to Register
ConstantRange Range(APInt(BitWidth, Low), APInt(BitWidth, High))
This file defines the SmallString class.
uint64_t getZExtValue() const
Get zero extended value.
unsigned getBitWidth() const
Return the number of bits in the APInt.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
size_t size() const
size - Get the array size.
This class is intended to be used as a driving class for all asm writers.
MachineFunction * MF
The current machine function.
const DataLayout & getDataLayout() const
Return information about data layout.
MCSymbol * GetExternalSymbolSymbol(const Twine &Sym) const
Return the MCSymbol for the specified ExternalSymbol.
Functions, function parameters, and return types can have attributes to indicate how they should be t...
unsigned getLineNo() const
StringRef getName() const
DIScope * getScope() const
DIGlobalVariable * getDecl() const
static LLVM_ABI std::optional< DebugEmissionKind > getEmissionKind(StringRef Str)
DIEBlock - Represents a block of values.
DwarfExpression implementation for singular DW_AT_location.
Represents a pointer to a location list in the debug_loc section.
DIELoc - Represents an expression location.
A structured debug information entry.
LLVM_ABI DIEValue findAttribute(dwarf::Attribute Attribute) const
Find a value in the DIE with the attribute given.
DIE & addChild(DIE *Child)
Add a child to the DIE.
DIE & addChildFront(DIE *Child)
static DIE * get(BumpPtrAllocator &Alloc, dwarf::Tag Tag)
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.
Holds a DIExpression and keeps track of how many operands have been consumed so far.
element_iterator elements_end() const
LLVM_ABI bool isEntryValue() const
Check if the expression consists of exactly one entry value operand.
static LLVM_ABI void appendOffset(SmallVectorImpl< uint64_t > &Ops, int64_t Offset)
Append Ops with operations to apply the Offset.
element_iterator elements_begin() const
ArrayRef< uint64_t > getElements() const
uint64_t getElement(unsigned I) const
LLVM_ABI std::optional< SignedOrUnsignedConstant > isConstant() const
Determine whether this represents a constant value, if so.
DIDerivedType * getStaticDataMemberDeclaration() const
MDTuple * getTemplateParams() const
bool isLocalToUnit() const
StringRef getLinkageName() const
StringRef getDisplayName() const
bool isDefinition() const
DINodeArray getAnnotations() const
An imported module (C++ using directive or similar).
bool isArtificial() const
std::optional< unsigned > getCoroSuspendIdx() const
DILocalScope * getScope() const
LLVM_ABI DISubprogram * getSubprogram() const
Get the subprogram for this scope.
LLVM_ABI DILocalScope * getNonLexicalBlockFileScope() const
Get the first non DILexicalBlockFile scope of this scope.
Tagged DWARF-like metadata node.
LLVM_ABI dwarf::Tag getTag() const
Base class for scope-like contexts.
Subprogram description. Uses SubclassData1.
uint32_t getAlignInBytes() const
DIScope * getScope() const
StringRef getName() const
LLVM_ABI unsigned getPointerSize(unsigned AS=0) const
The pointer representation size in bytes, rounded up to a whole number of bytes.
This class is defined as the common parent of DbgVariable and DbgLabel such that it could levarage po...
const DINode * getEntity() const
Accessors.
This class is used to track label information.
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.
ArrayRef< DbgValueLocEntry > getLocEntries() const
This class is used to track local variable information.
bool isArtificial() const
Return true if DbgVariable is artificial.
dwarf::Tag getTag() const
bool isObjectPointer() const
const DILocalVariable * getVariable() const
StringRef getName() const
const DIType * getType() const
Loc::Variant & asVariant()
To workaround P2162R0 https://github.com/cplusplus/papers/issues/873 the base class subobject needs t...
ValueT lookup(const_arg_type_t< KeyT > Val) const
lookup - Return the entry for the specified key, or a default constructed value if no such entry exis...
std::pair< iterator, bool > insert(const std::pair< KeyT, ValueT > &KV)
bool useGNUAnalogForDwarf5Feature() const
Whether to use the GNU analog for a DWARF5 tag, attribute, or location atom.
void constructCallSiteParmEntryDIEs(DIE &CallSiteDIE, SmallVector< DbgCallSiteParam, 4 > &Params)
Construct call site parameter DIEs for the CallSiteDIE.
void addLinkageNamesToDeclarations(const DwarfDebug &DD, const DISubprogram &CalleeSP, DIE &CalleeDIE)
void attachLowHighPC(DIE &D, const MCSymbol *Begin, const MCSymbol *End)
void emitHeader(bool UseOffsets) override
Emit the header for this unit, not including the initial length field.
dwarf::Tag getDwarf5OrGNUTag(dwarf::Tag Tag) const
This takes a DWARF 5 tag and returns it or a GNU analog.
void constructAbstractSubprogramScopeDIE(LexicalScope *Scope)
bool includeMinimalInlineScopes() const
DIE * getOrCreateImportedEntityDIE(const DIImportedEntity *IE)
Get or create a DIE for an imported entity.
void addBaseTypeRef(DIEValueList &Die, int64_t Idx)
void addGlobalNameForTypeUnit(StringRef Name, const DIScope *Context)
Add a new global name present in a type unit to this compile unit.
void finishEntityDefinition(const DbgEntity *Entity)
void addMemoryLocation(DIE &Die, dwarf::Attribute Attribute, const MachineLocation &Location, int64_t Offset)
Add a memory location exprloc to DIE with attribute Attribute at Location + Offset.
void addRange(RangeSpan Range)
addRange - Add an address range to the list of ranges for this unit.
void addAddrTableBase()
Add the DW_AT_addr_base attribute to the unit DIE.
std::vector< BaseTypeRef > ExprRefedBaseTypes
DIE * constructInlinedScopeDIE(LexicalScope *Scope, DIE &ParentScopeDIE)
This scope represents an inlined body of a function.
void createBaseTypeDIEs()
void addScopeRangeList(DIE &ScopeDIE, SmallVector< RangeSpan, 2 > Range)
A helper function to construct a RangeSpanList for a given lexical scope.
uint64_t getDWOId() const
DIE * getOrCreateCommonBlock(const DICommonBlock *CB, ArrayRef< GlobalExpr > GlobalExprs)
void addVariableAddress(const DbgVariable &DV, DIE &Die, MachineLocation Location)
Add DW_AT_location attribute for a DbgVariable based on provided MachineLocation.
DIE & constructCallSiteEntryDIE(DIE &ScopeDIE, const DISubprogram *CalleeSP, const Function *CalleeF, bool IsTail, const MCSymbol *PCAddr, const MCSymbol *CallAddr, MachineLocation CallTarget, int64_t Offset, DIType *AllocSiteTy)
Construct a call site entry DIE describing a call within Scope to a callee described by CalleeSP and ...
DIE & getOrCreateAbstractSubprogramDIE(const DISubprogram *SP)
Create an abstract subprogram DIE, that should later be populated by constructAbstractSubprogramScope...
DIE & constructSubprogramScopeDIE(const DISubprogram *Sub, const Function &F, LexicalScope *Scope, MCSymbol *LineTableSym)
Construct a DIE for this subprogram scope.
void addGlobalName(StringRef Name, const DIE &Die, const DIScope *Context) override
Add a new global name to the compile unit.
DIE & updateSubprogramScopeDIE(const DISubprogram *SP, const Function &F, MCSymbol *LineTableSym)
Find DIE for the given subprogram and attach appropriate DW_AT_low_pc, DW_AT_high_pc and DW_AT_LLVM_s...
void createAbstractEntity(const DINode *Node, LexicalScope *Scope)
void applyStmtList(DIE &D)
Apply the DW_AT_stmt_list from this compile unit to the specified DIE.
DIE * getOrCreateSubprogramDIE(const DISubprogram *SP, const Function *F, bool Minimal=false) override
DIE * getOrCreateContextDIE(const DIScope *Ty) override
Construct a DIE for a given scope.
void applyCommonDbgVariableAttributes(const DbgVariable &Var, DIE &VariableDie)
Add attributes to Var which reflect the common attributes of VariableDie, namely those which are not ...
DIE * constructVariableDIE(DbgVariable &DV, bool Abstract=false)
Construct a DIE for the given DbgVariable.
dwarf::LocationAtom getDwarf5OrGNULocationAtom(dwarf::LocationAtom Loc) const
This takes a DWARF 5 location atom and either returns it or a GNU analog.
DIE * getLocalContextDIE(const DILexicalBlock *LB)
Get DW_TAG_lexical_block for the given DILexicalBlock if available, or the most close parent DIE,...
DIE * getOrCreateGlobalVariableDIE(const DIGlobalVariable *GV, ArrayRef< GlobalExpr > GlobalExprs)
Get or create global variable DIE.
void addLocationAttribute(DIE *ToDIE, const DIGlobalVariable *GV, ArrayRef< GlobalExpr > GlobalExprs)
void applySubprogramAttributesToDefinition(const DISubprogram *SP, DIE &SPDie)
DIE * createAndAddScopeChildren(LexicalScope *Scope, DIE &ScopeDIE)
void addExpr(DIELoc &Die, dwarf::Form Form, const MCExpr *Expr)
Add a Dwarf expression attribute data and value.
DIE * getOrCreateLexicalBlockDIE(LexicalScope *Scope, DIE &ParentDIE)
Get if available or create a new DW_TAG_lexical_block for the given LexicalScope and attach DW_AT_low...
dwarf::Attribute getDwarf5OrGNUAttr(dwarf::Attribute Attr) const
This takes a DWARF 5 attribute and returns it or a GNU analog.
void addAddress(DIE &Die, dwarf::Attribute Attribute, const MachineLocation &Location)
Add an address attribute to a die based on the location provided.
void applyLabelAttributes(const DbgLabel &Label, DIE &LabelDie)
void addLocalLabelAddress(DIE &Die, dwarf::Attribute Attribute, const MCSymbol *Label)
addLocalLabelAddress - Add a dwarf label attribute data and value using DW_FORM_addr only.
void addGlobalTypeImpl(const DIType *Ty, const DIE &Die, const DIScope *Context) override
Add a new global type to the compile unit.
unsigned getOrCreateSourceID(const DIFile *File) override
Look up the source ID for the given file.
void constructScopeDIE(LexicalScope *Scope, DIE &ParentScopeDIE)
void attachLexicalScopesAbstractOrigins()
DwarfCompileUnit(unsigned UID, const DICompileUnit *Node, AsmPrinter *A, DwarfDebug *DW, DwarfFile *DWU, UnitKind Kind=UnitKind::Full)
DIE * constructLabelDIE(DbgLabel &DL, const LexicalScope &Scope)
Construct a DIE for the given DbgLabel.
void addGlobalTypeUnitType(const DIType *Ty, const DIScope *Context)
Add a new global type present in a type unit to this compile unit.
DbgEntity * getExistingAbstractEntity(const DINode *Node)
bool hasDwarfPubSections() const
void addLabelAddress(DIE &Die, dwarf::Attribute Attribute, const MCSymbol *Label)
addLabelAddress - Add a dwarf label attribute data and value using either DW_FORM_addr or DW_FORM_GNU...
void addLocationList(DIE &Die, dwarf::Attribute Attribute, unsigned Index)
Add a Dwarf loclistptr attribute data and value.
bool emitFuncLineTableOffsets() const
void addComplexAddress(const DIExpression *DIExpr, DIE &Die, dwarf::Attribute Attribute, const MachineLocation &Location)
Start with the address based on the location provided, and generate the DWARF information necessary t...
DIE * constructImportedEntityDIE(const DIImportedEntity *IE)
DwarfCompileUnit & getCU() override
void attachRangesOrLowHighPC(DIE &D, SmallVector< RangeSpan, 2 > Ranges)
void finishSubprogramDefinition(const DISubprogram *SP)
Collects and handles dwarf debug information.
uint16_t getDwarfVersion() const
Returns the Dwarf Version.
DwarfCompileUnit * lookupCU(const DIE *Die)
Find the matching DwarfCompileUnit for the given CU DIE.
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.
virtual void addTargetVariableAttributes(DwarfCompileUnit &CU, DIE &Die, std::optional< unsigned > TargetAddrSpace, VariableLocationKind VarLocKind, const GlobalVariable *GV=nullptr) const
Add target-specific attributes to a variable DIE (e.g.
void addAccelName(const DwarfUnit &Unit, const DICompileUnit::DebugNameTableKind NameTableKind, StringRef Name, const DIE &Die)
void setLocation(const MachineLocation &Loc, const DIExpression *DIExpr)
Set the location (Loc) and DIExpression (DIExpr) to describe.
void addFragmentOffset(const DIExpression *Expr)
If applicable, emit an empty DW_OP_piece / DW_OP_bit_piece to advance to the fragment described by Ex...
std::optional< uint8_t > TagOffset
void setCallSiteParamValueFlag()
Lock this down to become a call site parameter location.
bool addMachineRegExpression(const TargetRegisterInfo &TRI, DIExpressionCursor &Expr, llvm::Register MachineReg, unsigned FragmentOffsetInBits=0)
Emit a machine register location.
void addExpression(DIExpressionCursor &&Expr)
Emit all remaining operations in the DIExpressionCursor.
void addWasmLocation(unsigned Index, uint64_t Offset)
Emit location information expressed via WebAssembly location + offset The Index is an identifier for ...
void beginEntryValueExpression(DIExpressionCursor &ExprCursor)
Begin emission of an entry value dwarf operation.
virtual DIE * getOrCreateTypeDIE(const MDNode *TyNode)
Find existing DIE or create new DIE for the given type.
DwarfDebug & getDwarfDebug() const
void addAnnotation(DIE &Buffer, DINodeArray Annotations)
Add DW_TAG_LLVM_annotation.
void addBlock(DIE &Die, dwarf::Attribute Attribute, DIELoc *Loc)
Add block data.
void addTemplateParams(DIE &Buffer, DINodeArray TParams)
Add template parameters in buffer.
virtual DIE * getOrCreateContextDIE(const DIScope *Context)
Get context owner's DIE.
void addAttribute(DIEValueList &Die, dwarf::Attribute Attribute, dwarf::Form Form, T &&Value)
void addOpAddress(DIELoc &Die, const MCSymbol *Sym)
Add a dwarf op address data and value using the form given and an op of either DW_FORM_addr or DW_FOR...
void addUInt(DIEValueList &Die, dwarf::Attribute Attribute, std::optional< dwarf::Form > Form, uint64_t Integer)
Add an unsigned integer attribute data and value.
void addString(DIE &Die, dwarf::Attribute Attribute, StringRef Str)
Add a string attribute data and value.
void addConstantValue(DIE &Die, const ConstantInt *CI, const DIType *Ty)
Add constant value entry in variable DIE.
DIE * getOrCreateNameSpace(const DINamespace *NS)
void insertDIE(const DINode *Desc, DIE *D)
Insert DIE into the map.
void addSectionDelta(DIE &Die, dwarf::Attribute Attribute, const MCSymbol *Hi, const MCSymbol *Lo)
addSectionDelta - Add a label delta attribute data and value.
bool shouldPlaceInUnitDIE(const DISubprogram *SP, bool Minimal)
const DICompileUnit * CUNode
MDNode for the compile unit.
virtual DIE * getOrCreateSubprogramDIE(const DISubprogram *SP, const Function *FnHint, bool Minimal=false)
DIE * getOrCreateSubprogramContextDIE(const DISubprogram *SP, bool IgnoreScope)
DIE * getDIE(const DINode *D) const
Returns the DIE map slot for the specified debug variable.
MCSymbol * LabelBegin
The start of the unit within its section.
void addSInt(DIEValueList &Die, dwarf::Attribute Attribute, std::optional< dwarf::Form > Form, int64_t Integer)
Add an signed integer attribute data and value.
DwarfUnit(dwarf::Tag, const DICompileUnit *Node, AsmPrinter *A, DwarfDebug *DW, DwarfFile *DWU, unsigned UniqueID=0)
void addLabelDelta(DIEValueList &Die, dwarf::Attribute Attribute, const MCSymbol *Hi, const MCSymbol *Lo)
Add a label delta attribute data and value.
void addLinkageName(DIE &Die, StringRef LinkageName)
Add a linkage name, if it isn't empty.
std::string getParentContextString(const DIScope *Context) const
Get string containing language specific context for a global name.
void addSourceLine(DIE &Die, unsigned Line, unsigned Column, const DIFile *File)
Add location information to specified debug information entry.
void emitCommonHeader(bool UseOffsets, dwarf::UnitType UT)
Emit the common part of the header for this unit.
BumpPtrAllocator DIEValueAllocator
DIE * getOrCreateModule(const DIModule *M)
const DICompileUnit * getCUNode() const
DIE & createAndAddDIE(dwarf::Tag Tag, DIE &Parent, const DINode *N=nullptr)
Create a DIE with the given Tag, add the DIE to its parent, and call insertDIE if MD is not null.
DIE * getOrCreateStaticMemberDIE(const DIDerivedType *DT)
Create new static data member DIE.
void addLabel(DIEValueList &Die, dwarf::Attribute Attribute, dwarf::Form Form, const MCSymbol *Label)
Add a Dwarf label attribute data and value.
void addConstantFPValue(DIE &Die, const ConstantFP *CFP)
Add constant value entry in variable DIE.
void addSectionLabel(DIE &Die, dwarf::Attribute Attribute, const MCSymbol *Label, const MCSymbol *Sec)
Add a Dwarf section label attribute data and value.
void addPoolOpAddress(DIEValueList &Die, const MCSymbol *Label)
void constructTypeDIE(DIE &Buffer, const DICompositeType *CTy)
MCSymbol * EndLabel
Emitted at the end of the CU and used to compute the CU Length field.
void addFlag(DIE &Die, dwarf::Attribute Attribute)
Add a flag that is true to the DIE.
AsmPrinter * Asm
Target of Dwarf emission.
unsigned getUniqueID() const
Gets Unique ID for this unit.
void addType(DIE &Entity, const DIType *Ty, dwarf::Attribute Attribute=dwarf::DW_AT_type)
Add a new type attribute to the specified entity.
void applySubprogramAttributes(const DISubprogram *SP, DIE &SPDie, bool SkipSPAttributes=false)
void addDIEEntry(DIE &Die, dwarf::Attribute Attribute, DIE &Entry)
Add a DIE attribute data and value.
This class is used to track scope information.
Multi-value location description.
unsigned getDebugLocListIndex() const
std::optional< uint8_t > getDebugLocListTagOffset() const
Single value location description.
Base class for the full range of assembler expressions which are needed for parsing.
MCSection * getDwarfRangesSection() const
MCSection * getDwarfAddrSection() const
MCSection * getDwarfLineSection() const
MCSymbol * getBeginSymbol()
void setType(wasm::WasmSymbolType type)
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
bool isDefined() const
isDefined - Check if this symbol is defined (i.e., it has an address).
const TargetSubtargetInfo & getSubtarget() const
getSubtarget - Return the subtarget for which this machine code is being compiled.
A Module instance is used to store all the information related to an LLVM module.
StringRef getName() const
Get a short "name" for the module.
Wrapper class representing virtual and physical registers.
static constexpr bool isPhysicalRegister(unsigned Reg)
Return true if the specified register number is in the physical register namespace.
Implements a dense probed hash-table based set with some number of buckets stored inline.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
This class consists of common code factored out of the SmallVector class to reduce code duplication b...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringRef - Represent a constant reference to a string, i.e.
constexpr bool empty() const
empty - Check if the string is empty.
Information about stack frame layout on the target.
virtual DwarfFrameBase getDwarfFrameBase(const MachineFunction &MF) const
Return the frame base information to be encoded in the DWARF subprogram debug info.
virtual StackOffset getFrameIndexReference(const MachineFunction &MF, int FI, Register &FrameReg) const
getFrameIndexReference - This method should return the base register and offset used to reference a f...
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
virtual const TargetRegisterInfo * getRegisterInfo() const =0
Return the target's register information.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
StringRef toStringRef(SmallVectorImpl< char > &Out) const
This returns the twine as a single StringRef if it can be represented as such.
std::pair< iterator, bool > insert(const ValueT &V)
size_type count(const_arg_type_t< ValueT > V) const
Return 1 if the specified key is in the set, 0 otherwise.
A DeclContext is a named program scope that is used for ODR uniquing of types.
LLVM_ABI StringRef AttributeEncodingString(unsigned Encoding)
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
initializer< Ty > init(const Ty &Val)
UnitType
Constants for unit types in DWARF v5.
@ WASM_SYMBOL_TYPE_GLOBAL
This is an optimization pass for GlobalISel generic memory operations.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
auto dyn_cast_if_present(const Y &Val)
dyn_cast_if_present<X> - Functionally identical to dyn_cast, except that a null (or none in the case ...
bool isRangeRelaxable(const MCSymbol *Begin, const MCSymbol *End)
bool isa_and_nonnull(const Y &Val)
std::pair< const MachineInstr *, const MachineInstr * > InsnRange
This is used to track range of instructions with identical lexical scope.
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
auto reverse(ContainerTy &&C)
@ Apple
.apple_names, .apple_namespaces, .apple_types, .apple_objc.
FunctionAddr VTableAddr Count
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...
@ Global
Append to llvm.global_dtors.
constexpr T divideCeil(U Numerator, V Denominator)
Returns the integer ceil(Numerator / Denominator).
@ Sub
Subtraction of integers.
auto count(R &&Range, const E &Element)
Wrapper function around std::count to count the number of times an element Element occurs in the give...
DWARFExpression::Operation Op
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
LLVM_ABI DISubprogram * getDISubprogram(const MDNode *Scope)
Find subprogram that is enclosing this scope.
Single location defined by (potentially multiple) EntryValueInfo.
std::set< EntryValueInfo > EntryValues
Single location defined by (potentially multiple) MMI entries.
const std::set< FrameIndexExpr > & getFrameIndexExprs() const
Get the FI entries, sorted by fragment offset.
Helper used to pair up a symbol and its DWARF compile unit.
union llvm::TargetFrameLowering::DwarfFrameBase::@004076321055032247336074224075335064105264310375 Location
enum llvm::TargetFrameLowering::DwarfFrameBase::FrameBaseKind Kind
struct WasmFrameBase WasmLoc