1 //===- llvm/IR/DebugInfoMetadata.h - Debug info metadata --------*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // Declarations for metadata specific to debug info.
12 //===----------------------------------------------------------------------===//
14 #ifndef LLVM_IR_DEBUGINFOMETADATA_H
15 #define LLVM_IR_DEBUGINFOMETADATA_H
17 #include "llvm/IR/Metadata.h"
18 #include "llvm/Support/Dwarf.h"
20 // Helper macros for defining get() overrides.
21 #define DEFINE_MDNODE_GET_UNPACK_IMPL(...) __VA_ARGS__
22 #define DEFINE_MDNODE_GET_UNPACK(ARGS) DEFINE_MDNODE_GET_UNPACK_IMPL ARGS
23 #define DEFINE_MDNODE_GET(CLASS, FORMAL, ARGS) \
24 static CLASS *get(LLVMContext &Context, DEFINE_MDNODE_GET_UNPACK(FORMAL)) { \
25 return getImpl(Context, DEFINE_MDNODE_GET_UNPACK(ARGS), Uniqued); \
27 static CLASS *getIfExists(LLVMContext &Context, \
28 DEFINE_MDNODE_GET_UNPACK(FORMAL)) { \
29 return getImpl(Context, DEFINE_MDNODE_GET_UNPACK(ARGS), Uniqued, \
30 /* ShouldCreate */ false); \
32 static CLASS *getDistinct(LLVMContext &Context, \
33 DEFINE_MDNODE_GET_UNPACK(FORMAL)) { \
34 return getImpl(Context, DEFINE_MDNODE_GET_UNPACK(ARGS), Distinct); \
36 static Temp##CLASS getTemporary(LLVMContext &Context, \
37 DEFINE_MDNODE_GET_UNPACK(FORMAL)) { \
39 getImpl(Context, DEFINE_MDNODE_GET_UNPACK(ARGS), Temporary)); \
44 /// \brief Debug location.
46 /// A debug location in source code, used for debug info and otherwise.
47 class MDLocation : public MDNode {
48 friend class LLVMContextImpl;
51 MDLocation(LLVMContext &C, StorageType Storage, unsigned Line,
52 unsigned Column, ArrayRef<Metadata *> MDs);
53 ~MDLocation() { dropAllReferences(); }
55 static MDLocation *getImpl(LLVMContext &Context, unsigned Line,
56 unsigned Column, Metadata *Scope,
57 Metadata *InlinedAt, StorageType Storage,
58 bool ShouldCreate = true);
60 TempMDLocation cloneImpl() const {
61 return getTemporary(getContext(), getLine(), getColumn(), getScope(),
65 // Disallow replacing operands.
66 void replaceOperandWith(unsigned I, Metadata *New) = delete;
69 DEFINE_MDNODE_GET(MDLocation,
70 (unsigned Line, unsigned Column, Metadata *Scope,
71 Metadata *InlinedAt = nullptr),
72 (Line, Column, Scope, InlinedAt))
74 /// \brief Return a (temporary) clone of this.
75 TempMDLocation clone() const { return cloneImpl(); }
77 unsigned getLine() const { return SubclassData32; }
78 unsigned getColumn() const { return SubclassData16; }
79 Metadata *getScope() const { return getOperand(0); }
80 Metadata *getInlinedAt() const {
81 if (getNumOperands() == 2)
86 static bool classof(const Metadata *MD) {
87 return MD->getMetadataID() == MDLocationKind;
91 /// \brief Tagged DWARF-like metadata node.
93 /// A metadata node with a DWARF tag (i.e., a constant named \c DW_TAG_*,
94 /// defined in llvm/Support/Dwarf.h). Called \a DebugNode because it's
95 /// potentially used for non-DWARF output.
96 class DebugNode : public MDNode {
97 friend class LLVMContextImpl;
101 DebugNode(LLVMContext &C, unsigned ID, StorageType Storage, unsigned Tag,
102 ArrayRef<Metadata *> Ops1, ArrayRef<Metadata *> Ops2 = None)
103 : MDNode(C, ID, Storage, Ops1, Ops2) {
104 assert(Tag < 1u << 16);
105 SubclassData16 = Tag;
109 template <class Ty> Ty *getOperandAs(unsigned I) const {
110 return cast_or_null<Ty>(getOperand(I));
113 StringRef getStringOperand(unsigned I) const {
114 if (auto *S = getOperandAs<MDString>(I))
115 return S->getString();
119 static MDString *getCanonicalMDString(LLVMContext &Context, StringRef S) {
122 return MDString::get(Context, S);
126 unsigned getTag() const { return SubclassData16; }
128 static bool classof(const Metadata *MD) {
129 switch (MD->getMetadataID()) {
132 case GenericDebugNodeKind:
134 case MDEnumeratorKind:
135 case MDBasicTypeKind:
136 case MDDerivedTypeKind:
137 case MDCompositeTypeKind:
138 case MDSubroutineTypeKind:
140 case MDCompileUnitKind:
141 case MDSubprogramKind:
142 case MDLexicalBlockKind:
143 case MDLexicalBlockFileKind:
144 case MDNamespaceKind:
145 case MDTemplateTypeParameterKind:
146 case MDTemplateValueParameterKind:
147 case MDGlobalVariableKind:
148 case MDLocalVariableKind:
149 case MDExpressionKind:
150 case MDObjCPropertyKind:
151 case MDImportedEntityKind:
157 /// \brief Generic tagged DWARF-like metadata node.
159 /// An un-specialized DWARF-like metadata node. The first operand is a
160 /// (possibly empty) null-separated \a MDString header that contains arbitrary
161 /// fields. The remaining operands are \a dwarf_operands(), and are pointers
162 /// to other metadata.
163 class GenericDebugNode : public DebugNode {
164 friend class LLVMContextImpl;
167 GenericDebugNode(LLVMContext &C, StorageType Storage, unsigned Hash,
168 unsigned Tag, ArrayRef<Metadata *> Ops1,
169 ArrayRef<Metadata *> Ops2)
170 : DebugNode(C, GenericDebugNodeKind, Storage, Tag, Ops1, Ops2) {
173 ~GenericDebugNode() { dropAllReferences(); }
175 void setHash(unsigned Hash) { SubclassData32 = Hash; }
176 void recalculateHash();
178 static GenericDebugNode *getImpl(LLVMContext &Context, unsigned Tag,
180 ArrayRef<Metadata *> DwarfOps,
182 bool ShouldCreate = true) {
183 return getImpl(Context, Tag, getCanonicalMDString(Context, Header),
184 DwarfOps, Storage, ShouldCreate);
187 static GenericDebugNode *getImpl(LLVMContext &Context, unsigned Tag,
189 ArrayRef<Metadata *> DwarfOps,
191 bool ShouldCreate = true);
193 TempGenericDebugNode cloneImpl() const {
195 getContext(), getTag(), getHeader(),
196 SmallVector<Metadata *, 4>(dwarf_op_begin(), dwarf_op_end()));
200 unsigned getHash() const { return SubclassData32; }
202 DEFINE_MDNODE_GET(GenericDebugNode, (unsigned Tag, StringRef Header,
203 ArrayRef<Metadata *> DwarfOps),
204 (Tag, Header, DwarfOps))
205 DEFINE_MDNODE_GET(GenericDebugNode, (unsigned Tag, MDString *Header,
206 ArrayRef<Metadata *> DwarfOps),
207 (Tag, Header, DwarfOps))
209 /// \brief Return a (temporary) clone of this.
210 TempGenericDebugNode clone() const { return cloneImpl(); }
212 unsigned getTag() const { return SubclassData16; }
213 StringRef getHeader() const { return getStringOperand(0); }
215 op_iterator dwarf_op_begin() const { return op_begin() + 1; }
216 op_iterator dwarf_op_end() const { return op_end(); }
217 op_range dwarf_operands() const {
218 return op_range(dwarf_op_begin(), dwarf_op_end());
221 unsigned getNumDwarfOperands() const { return getNumOperands() - 1; }
222 const MDOperand &getDwarfOperand(unsigned I) const {
223 return getOperand(I + 1);
225 void replaceDwarfOperandWith(unsigned I, Metadata *New) {
226 replaceOperandWith(I + 1, New);
229 static bool classof(const Metadata *MD) {
230 return MD->getMetadataID() == GenericDebugNodeKind;
234 /// \brief Array subrange.
236 /// TODO: Merge into node for DW_TAG_array_type, which should have a custom
238 class MDSubrange : public DebugNode {
239 friend class LLVMContextImpl;
245 MDSubrange(LLVMContext &C, StorageType Storage, int64_t Count, int64_t Lo)
246 : DebugNode(C, MDSubrangeKind, Storage, dwarf::DW_TAG_subrange_type,
248 Count(Count), Lo(Lo) {}
251 static MDSubrange *getImpl(LLVMContext &Context, int64_t Count, int64_t Lo,
252 StorageType Storage, bool ShouldCreate = true);
254 TempMDSubrange cloneImpl() const {
255 return getTemporary(getContext(), getCount(), getLo());
259 DEFINE_MDNODE_GET(MDSubrange, (int64_t Count, int64_t Lo = 0), (Count, Lo))
261 TempMDSubrange clone() const { return cloneImpl(); }
263 int64_t getLo() const { return Lo; }
264 int64_t getCount() const { return Count; }
266 static bool classof(const Metadata *MD) {
267 return MD->getMetadataID() == MDSubrangeKind;
271 /// \brief Enumeration value.
273 /// TODO: Add a pointer to the context (DW_TAG_enumeration_type) once that no
274 /// longer creates a type cycle.
275 class MDEnumerator : public DebugNode {
276 friend class LLVMContextImpl;
281 MDEnumerator(LLVMContext &C, StorageType Storage, int64_t Value,
282 ArrayRef<Metadata *> Ops)
283 : DebugNode(C, MDEnumeratorKind, Storage, dwarf::DW_TAG_enumerator, Ops),
287 static MDEnumerator *getImpl(LLVMContext &Context, int64_t Value,
288 StringRef Name, StorageType Storage,
289 bool ShouldCreate = true) {
290 return getImpl(Context, Value, getCanonicalMDString(Context, Name), Storage,
293 static MDEnumerator *getImpl(LLVMContext &Context, int64_t Value,
294 MDString *Name, StorageType Storage,
295 bool ShouldCreate = true);
297 TempMDEnumerator cloneImpl() const {
298 return getTemporary(getContext(), getValue(), getName());
302 DEFINE_MDNODE_GET(MDEnumerator, (int64_t Value, StringRef Name),
304 DEFINE_MDNODE_GET(MDEnumerator, (int64_t Value, MDString *Name),
307 TempMDEnumerator clone() const { return cloneImpl(); }
309 int64_t getValue() const { return Value; }
310 StringRef getName() const { return getStringOperand(0); }
312 MDString *getRawName() const { return getOperandAs<MDString>(0); }
314 static bool classof(const Metadata *MD) {
315 return MD->getMetadataID() == MDEnumeratorKind;
319 /// \brief Base class for scope-like contexts.
321 /// Base class for lexical scopes and types (which are also declaration
324 /// TODO: Separate the concepts of declaration contexts and lexical scopes.
325 class MDScope : public DebugNode {
327 MDScope(LLVMContext &C, unsigned ID, StorageType Storage, unsigned Tag,
328 ArrayRef<Metadata *> Ops)
329 : DebugNode(C, ID, Storage, Tag, Ops) {}
333 Metadata *getFile() const { return getOperand(0); }
335 static bool classof(const Metadata *MD) {
336 switch (MD->getMetadataID()) {
339 case MDBasicTypeKind:
340 case MDDerivedTypeKind:
341 case MDCompositeTypeKind:
342 case MDSubroutineTypeKind:
344 case MDCompileUnitKind:
345 case MDSubprogramKind:
346 case MDLexicalBlockKind:
347 case MDLexicalBlockFileKind:
348 case MDNamespaceKind:
354 /// \brief Base class for types.
356 /// TODO: Remove the hardcoded name and context, since many types don't use
358 /// TODO: Split up flags.
359 class MDType : public MDScope {
362 unsigned AlignInBits;
363 unsigned OffsetInBits;
367 MDType(LLVMContext &C, unsigned ID, StorageType Storage, unsigned Tag,
368 unsigned Line, unsigned SizeInBits, unsigned AlignInBits,
369 unsigned OffsetInBits, unsigned Flags, ArrayRef<Metadata *> Ops)
370 : MDScope(C, ID, Storage, Tag, Ops), Line(Line), SizeInBits(SizeInBits),
371 AlignInBits(AlignInBits), OffsetInBits(OffsetInBits), Flags(Flags) {}
375 unsigned getLine() const { return Line; }
376 unsigned getSizeInBits() const { return SizeInBits; }
377 unsigned getAlignInBits() const { return AlignInBits; }
378 unsigned getOffsetInBits() const { return OffsetInBits; }
379 unsigned getFlags() const { return Flags; }
381 Metadata *getScope() const { return getOperand(1); }
382 StringRef getName() const { return getStringOperand(2); }
384 MDString *getRawName() const { return getOperandAs<MDString>(2); }
386 static bool classof(const Metadata *MD) {
387 switch (MD->getMetadataID()) {
390 case MDBasicTypeKind:
391 case MDDerivedTypeKind:
392 case MDCompositeTypeKind:
393 case MDSubroutineTypeKind:
399 /// \brief Basic type.
401 /// TODO: Split out DW_TAG_unspecified_type.
402 /// TODO: Drop unused accessors.
403 class MDBasicType : public MDType {
404 friend class LLVMContextImpl;
409 MDBasicType(LLVMContext &C, StorageType Storage, unsigned Tag,
410 unsigned SizeInBits, unsigned AlignInBits, unsigned Encoding,
411 ArrayRef<Metadata *> Ops)
412 : MDType(C, MDBasicTypeKind, Storage, Tag, 0, SizeInBits, AlignInBits, 0,
414 Encoding(Encoding) {}
417 static MDBasicType *getImpl(LLVMContext &Context, unsigned Tag,
418 StringRef Name, unsigned SizeInBits,
419 unsigned AlignInBits, unsigned Encoding,
420 StorageType Storage, bool ShouldCreate = true) {
421 return getImpl(Context, Tag, getCanonicalMDString(Context, Name),
422 SizeInBits, AlignInBits, Encoding, Storage, ShouldCreate);
424 static MDBasicType *getImpl(LLVMContext &Context, unsigned Tag,
425 MDString *Name, unsigned SizeInBits,
426 unsigned AlignInBits, unsigned Encoding,
427 StorageType Storage, bool ShouldCreate = true);
429 TempMDBasicType cloneImpl() const {
430 return getTemporary(getContext(), getTag(), getName(), getSizeInBits(),
431 getAlignInBits(), getEncoding());
435 DEFINE_MDNODE_GET(MDBasicType,
436 (unsigned Tag, StringRef Name, unsigned SizeInBits,
437 unsigned AlignInBits, unsigned Encoding),
438 (Tag, Name, SizeInBits, AlignInBits, Encoding))
439 DEFINE_MDNODE_GET(MDBasicType,
440 (unsigned Tag, MDString *Name, unsigned SizeInBits,
441 unsigned AlignInBits, unsigned Encoding),
442 (Tag, Name, SizeInBits, AlignInBits, Encoding))
444 TempMDBasicType clone() const { return cloneImpl(); }
446 unsigned getEncoding() const { return Encoding; }
448 static bool classof(const Metadata *MD) {
449 return MD->getMetadataID() == MDBasicTypeKind;
453 /// \brief Base class for MDDerivedType and MDCompositeType.
455 /// TODO: Delete; they're not really related.
456 class MDDerivedTypeBase : public MDType {
458 MDDerivedTypeBase(LLVMContext &C, unsigned ID, StorageType Storage,
459 unsigned Tag, unsigned Line, unsigned SizeInBits,
460 unsigned AlignInBits, unsigned OffsetInBits, unsigned Flags,
461 ArrayRef<Metadata *> Ops)
462 : MDType(C, ID, Storage, Tag, Line, SizeInBits, AlignInBits, OffsetInBits,
464 ~MDDerivedTypeBase() {}
467 Metadata *getBaseType() const { return getOperand(3); }
469 static bool classof(const Metadata *MD) {
470 return MD->getMetadataID() == MDDerivedTypeKind ||
471 MD->getMetadataID() == MDCompositeTypeKind ||
472 MD->getMetadataID() == MDSubroutineTypeKind;
476 /// \brief Derived types.
478 /// This includes qualified types, pointers, references, friends, typedefs, and
481 /// TODO: Split out members (inheritance, fields, methods, etc.).
482 class MDDerivedType : public MDDerivedTypeBase {
483 friend class LLVMContextImpl;
486 MDDerivedType(LLVMContext &C, StorageType Storage, unsigned Tag,
487 unsigned Line, unsigned SizeInBits, unsigned AlignInBits,
488 unsigned OffsetInBits, unsigned Flags, ArrayRef<Metadata *> Ops)
489 : MDDerivedTypeBase(C, MDDerivedTypeKind, Storage, Tag, Line, SizeInBits,
490 AlignInBits, OffsetInBits, Flags, Ops) {}
493 static MDDerivedType *getImpl(LLVMContext &Context, unsigned Tag,
494 StringRef Name, Metadata *File, unsigned Line,
495 Metadata *Scope, Metadata *BaseType,
496 unsigned SizeInBits, unsigned AlignInBits,
497 unsigned OffsetInBits, unsigned Flags,
498 Metadata *ExtraData, StorageType Storage,
499 bool ShouldCreate = true) {
500 return getImpl(Context, Tag, getCanonicalMDString(Context, Name), File,
501 Line, Scope, BaseType, SizeInBits, AlignInBits, OffsetInBits,
502 Flags, ExtraData, Storage, ShouldCreate);
504 static MDDerivedType *getImpl(LLVMContext &Context, unsigned Tag,
505 MDString *Name, Metadata *File, unsigned Line,
506 Metadata *Scope, Metadata *BaseType,
507 unsigned SizeInBits, unsigned AlignInBits,
508 unsigned OffsetInBits, unsigned Flags,
509 Metadata *ExtraData, StorageType Storage,
510 bool ShouldCreate = true);
512 TempMDDerivedType cloneImpl() const {
513 return getTemporary(getContext(), getTag(), getName(), getFile(), getLine(),
514 getScope(), getBaseType(), getSizeInBits(),
515 getAlignInBits(), getOffsetInBits(), getFlags(),
520 DEFINE_MDNODE_GET(MDDerivedType,
521 (unsigned Tag, MDString *Name, Metadata *File,
522 unsigned Line, Metadata *Scope, Metadata *BaseType,
523 unsigned SizeInBits, unsigned AlignInBits,
524 unsigned OffsetInBits, unsigned Flags,
525 Metadata *ExtraData = nullptr),
526 (Tag, Name, File, Line, Scope, BaseType, SizeInBits,
527 AlignInBits, OffsetInBits, Flags, ExtraData))
528 DEFINE_MDNODE_GET(MDDerivedType,
529 (unsigned Tag, StringRef Name, Metadata *File,
530 unsigned Line, Metadata *Scope, Metadata *BaseType,
531 unsigned SizeInBits, unsigned AlignInBits,
532 unsigned OffsetInBits, unsigned Flags,
533 Metadata *ExtraData = nullptr),
534 (Tag, Name, File, Line, Scope, BaseType, SizeInBits,
535 AlignInBits, OffsetInBits, Flags, ExtraData))
537 TempMDDerivedType clone() const { return cloneImpl(); }
539 /// \brief Get extra data associated with this derived type.
541 /// Class type for pointer-to-members, objective-c property node for ivars,
542 /// or global constant wrapper for static members.
544 /// TODO: Separate out types that need this extra operand: pointer-to-member
545 /// types and member fields (static members and ivars).
546 Metadata *getExtraData() const { return getOperand(4); }
548 static bool classof(const Metadata *MD) {
549 return MD->getMetadataID() == MDDerivedTypeKind;
553 /// \brief Base class for MDCompositeType and MDSubroutineType.
555 /// TODO: Delete; they're not really related.
556 class MDCompositeTypeBase : public MDDerivedTypeBase {
557 unsigned RuntimeLang;
560 MDCompositeTypeBase(LLVMContext &C, unsigned ID, StorageType Storage,
561 unsigned Tag, unsigned Line, unsigned RuntimeLang,
562 unsigned SizeInBits, unsigned AlignInBits,
563 unsigned OffsetInBits, unsigned Flags,
564 ArrayRef<Metadata *> Ops)
565 : MDDerivedTypeBase(C, ID, Storage, Tag, Line, SizeInBits, AlignInBits,
566 OffsetInBits, Flags, Ops),
567 RuntimeLang(RuntimeLang) {}
568 ~MDCompositeTypeBase() {}
571 Metadata *getElements() const { return getOperand(4); }
572 Metadata *getVTableHolder() const { return getOperand(5); }
573 Metadata *getTemplateParams() const { return getOperand(6); }
574 StringRef getIdentifier() const { return getStringOperand(7); }
575 unsigned getRuntimeLang() const { return RuntimeLang; }
577 MDString *getRawIdentifier() const { return getOperandAs<MDString>(7); }
579 /// \brief Replace operands.
581 /// If this \a isUniqued() and not \a isResolved(), on a uniquing collision
582 /// this will be RAUW'ed and deleted. Use a \a TrackingMDRef to keep track
583 /// of its movement if necessary.
585 void replaceElements(MDTuple *Elements) {
587 if (auto *Old = cast_or_null<MDTuple>(getElements()))
588 for (const auto &Op : Old->operands())
589 assert(std::find(Elements->op_begin(), Elements->op_end(), Op) &&
590 "Lost a member during member list replacement");
592 replaceOperandWith(4, Elements);
594 void replaceVTableHolder(Metadata *VTableHolder) {
595 replaceOperandWith(5, VTableHolder);
597 void replaceTemplateParams(MDTuple *TemplateParams) {
598 replaceOperandWith(6, TemplateParams);
602 static bool classof(const Metadata *MD) {
603 return MD->getMetadataID() == MDCompositeTypeKind ||
604 MD->getMetadataID() == MDSubroutineTypeKind;
608 /// \brief Composite types.
610 /// TODO: Detach from DerivedTypeBase (split out MDEnumType?).
611 /// TODO: Create a custom, unrelated node for DW_TAG_array_type.
612 class MDCompositeType : public MDCompositeTypeBase {
613 friend class LLVMContextImpl;
616 MDCompositeType(LLVMContext &C, StorageType Storage, unsigned Tag,
617 unsigned Line, unsigned RuntimeLang, unsigned SizeInBits,
618 unsigned AlignInBits, unsigned OffsetInBits, unsigned Flags,
619 ArrayRef<Metadata *> Ops)
620 : MDCompositeTypeBase(C, MDCompositeTypeKind, Storage, Tag, Line,
621 RuntimeLang, SizeInBits, AlignInBits, OffsetInBits,
623 ~MDCompositeType() {}
625 static MDCompositeType *
626 getImpl(LLVMContext &Context, unsigned Tag, StringRef Name, Metadata *File,
627 unsigned Line, Metadata *Scope, Metadata *BaseType,
628 unsigned SizeInBits, unsigned AlignInBits, unsigned OffsetInBits,
629 unsigned Flags, Metadata *Elements, unsigned RuntimeLang,
630 Metadata *VTableHolder, Metadata *TemplateParams,
631 StringRef Identifier, StorageType Storage, bool ShouldCreate = true) {
632 return getImpl(Context, Tag, getCanonicalMDString(Context, Name), File,
633 Line, Scope, BaseType, SizeInBits, AlignInBits, OffsetInBits,
634 Flags, Elements, RuntimeLang, VTableHolder, TemplateParams,
635 getCanonicalMDString(Context, Identifier), Storage,
638 static MDCompositeType *
639 getImpl(LLVMContext &Context, unsigned Tag, MDString *Name, Metadata *File,
640 unsigned Line, Metadata *Scope, Metadata *BaseType,
641 unsigned SizeInBits, unsigned AlignInBits, unsigned OffsetInBits,
642 unsigned Flags, Metadata *Elements, unsigned RuntimeLang,
643 Metadata *VTableHolder, Metadata *TemplateParams,
644 MDString *Identifier, StorageType Storage, bool ShouldCreate = true);
646 TempMDCompositeType cloneImpl() const {
647 return getTemporary(getContext(), getTag(), getName(), getFile(), getLine(),
648 getScope(), getBaseType(), getSizeInBits(),
649 getAlignInBits(), getOffsetInBits(), getFlags(),
650 getElements(), getRuntimeLang(), getVTableHolder(),
651 getTemplateParams(), getIdentifier());
655 DEFINE_MDNODE_GET(MDCompositeType,
656 (unsigned Tag, StringRef Name, Metadata *File,
657 unsigned Line, Metadata *Scope, Metadata *BaseType,
658 unsigned SizeInBits, unsigned AlignInBits,
659 unsigned OffsetInBits, unsigned Flags, Metadata *Elements,
660 unsigned RuntimeLang, Metadata *VTableHolder,
661 Metadata *TemplateParams = nullptr,
662 StringRef Identifier = ""),
663 (Tag, Name, File, Line, Scope, BaseType, SizeInBits,
664 AlignInBits, OffsetInBits, Flags, Elements, RuntimeLang,
665 VTableHolder, TemplateParams, Identifier))
666 DEFINE_MDNODE_GET(MDCompositeType,
667 (unsigned Tag, MDString *Name, Metadata *File,
668 unsigned Line, Metadata *Scope, Metadata *BaseType,
669 unsigned SizeInBits, unsigned AlignInBits,
670 unsigned OffsetInBits, unsigned Flags, Metadata *Elements,
671 unsigned RuntimeLang, Metadata *VTableHolder,
672 Metadata *TemplateParams = nullptr,
673 MDString *Identifier = nullptr),
674 (Tag, Name, File, Line, Scope, BaseType, SizeInBits,
675 AlignInBits, OffsetInBits, Flags, Elements, RuntimeLang,
676 VTableHolder, TemplateParams, Identifier))
678 TempMDCompositeType clone() const { return cloneImpl(); }
680 static bool classof(const Metadata *MD) {
681 return MD->getMetadataID() == MDCompositeTypeKind;
685 /// \brief Type array for a subprogram.
687 /// TODO: Detach from CompositeType, and fold the array of types in directly
689 class MDSubroutineType : public MDCompositeTypeBase {
690 friend class LLVMContextImpl;
693 MDSubroutineType(LLVMContext &C, StorageType Storage, unsigned Flags,
694 ArrayRef<Metadata *> Ops)
695 : MDCompositeTypeBase(C, MDSubroutineTypeKind, Storage,
696 dwarf::DW_TAG_subroutine_type, 0, 0, 0, 0, 0, Flags,
698 ~MDSubroutineType() {}
700 static MDSubroutineType *getImpl(LLVMContext &Context, unsigned Flags,
701 Metadata *TypeArray, StorageType Storage,
702 bool ShouldCreate = true);
704 TempMDSubroutineType cloneImpl() const {
705 return getTemporary(getContext(), getFlags(), getTypeArray());
709 DEFINE_MDNODE_GET(MDSubroutineType, (unsigned Flags, Metadata *TypeArray),
712 TempMDSubroutineType clone() const { return cloneImpl(); }
714 Metadata *getTypeArray() const { return getElements(); }
716 static bool classof(const Metadata *MD) {
717 return MD->getMetadataID() == MDSubroutineTypeKind;
723 /// TODO: Merge with directory/file node (including users).
724 /// TODO: Canonicalize paths on creation.
725 class MDFile : public MDScope {
726 friend class LLVMContextImpl;
729 MDFile(LLVMContext &C, StorageType Storage, ArrayRef<Metadata *> Ops)
730 : MDScope(C, MDFileKind, Storage, dwarf::DW_TAG_file_type, Ops) {}
733 static MDFile *getImpl(LLVMContext &Context, StringRef Filename,
734 StringRef Directory, StorageType Storage,
735 bool ShouldCreate = true) {
736 return getImpl(Context, getCanonicalMDString(Context, Filename),
737 getCanonicalMDString(Context, Directory), Storage,
740 static MDFile *getImpl(LLVMContext &Context, MDString *Filename,
741 MDString *Directory, StorageType Storage,
742 bool ShouldCreate = true);
744 TempMDFile cloneImpl() const {
745 return getTemporary(getContext(), getFilename(), getDirectory());
749 DEFINE_MDNODE_GET(MDFile, (StringRef Filename, StringRef Directory),
750 (Filename, Directory))
751 DEFINE_MDNODE_GET(MDFile, (MDString * Filename, MDString *Directory),
752 (Filename, Directory))
754 TempMDFile clone() const { return cloneImpl(); }
756 MDTuple *getFileNode() const { return cast<MDTuple>(getOperand(0)); }
758 StringRef getFilename() const {
759 if (auto *S = getRawFilename())
760 return S->getString();
763 StringRef getDirectory() const {
764 if (auto *S = getRawDirectory())
765 return S->getString();
769 MDString *getRawFilename() const {
770 return cast_or_null<MDString>(getFileNode()->getOperand(0));
772 MDString *getRawDirectory() const {
773 return cast_or_null<MDString>(getFileNode()->getOperand(1));
776 static bool classof(const Metadata *MD) {
777 return MD->getMetadataID() == MDFileKind;
781 /// \brief Compile unit.
782 class MDCompileUnit : public MDScope {
783 friend class LLVMContextImpl;
786 unsigned SourceLanguage;
788 unsigned RuntimeVersion;
789 unsigned EmissionKind;
791 MDCompileUnit(LLVMContext &C, StorageType Storage, unsigned SourceLanguage,
792 bool IsOptimized, unsigned RuntimeVersion,
793 unsigned EmissionKind, ArrayRef<Metadata *> Ops)
794 : MDScope(C, MDCompileUnitKind, Storage, dwarf::DW_TAG_compile_unit, Ops),
795 SourceLanguage(SourceLanguage), IsOptimized(IsOptimized),
796 RuntimeVersion(RuntimeVersion), EmissionKind(EmissionKind) {}
799 static MDCompileUnit *
800 getImpl(LLVMContext &Context, unsigned SourceLanguage, Metadata *File,
801 StringRef Producer, bool IsOptimized, StringRef Flags,
802 unsigned RuntimeVersion, StringRef SplitDebugFilename,
803 unsigned EmissionKind, Metadata *EnumTypes, Metadata *RetainedTypes,
804 Metadata *Subprograms, Metadata *GlobalVariables,
805 Metadata *ImportedEntities, StorageType Storage,
806 bool ShouldCreate = true) {
807 return getImpl(Context, SourceLanguage, File,
808 getCanonicalMDString(Context, Producer), IsOptimized,
809 getCanonicalMDString(Context, Flags), RuntimeVersion,
810 getCanonicalMDString(Context, SplitDebugFilename),
811 EmissionKind, EnumTypes, RetainedTypes, Subprograms,
812 GlobalVariables, ImportedEntities, Storage, ShouldCreate);
814 static MDCompileUnit *
815 getImpl(LLVMContext &Context, unsigned SourceLanguage, Metadata *File,
816 MDString *Producer, bool IsOptimized, MDString *Flags,
817 unsigned RuntimeVersion, MDString *SplitDebugFilename,
818 unsigned EmissionKind, Metadata *EnumTypes, Metadata *RetainedTypes,
819 Metadata *Subprograms, Metadata *GlobalVariables,
820 Metadata *ImportedEntities, StorageType Storage,
821 bool ShouldCreate = true);
823 TempMDCompileUnit cloneImpl() const {
825 getContext(), getSourceLanguage(), getFile(), getProducer(),
826 isOptimized(), getFlags(), getRuntimeVersion(), getSplitDebugFilename(),
827 getEmissionKind(), getEnumTypes(), getRetainedTypes(), getSubprograms(),
828 getGlobalVariables(), getImportedEntities());
832 DEFINE_MDNODE_GET(MDCompileUnit,
833 (unsigned SourceLanguage, Metadata *File,
834 StringRef Producer, bool IsOptimized, StringRef Flags,
835 unsigned RuntimeVersion, StringRef SplitDebugFilename,
836 unsigned EmissionKind, Metadata *EnumTypes,
837 Metadata *RetainedTypes, Metadata *Subprograms,
838 Metadata *GlobalVariables, Metadata *ImportedEntities),
839 (SourceLanguage, File, Producer, IsOptimized, Flags,
840 RuntimeVersion, SplitDebugFilename, EmissionKind,
841 EnumTypes, RetainedTypes, Subprograms, GlobalVariables,
843 DEFINE_MDNODE_GET(MDCompileUnit,
844 (unsigned SourceLanguage, Metadata *File,
845 MDString *Producer, bool IsOptimized, MDString *Flags,
846 unsigned RuntimeVersion, MDString *SplitDebugFilename,
847 unsigned EmissionKind, Metadata *EnumTypes,
848 Metadata *RetainedTypes, Metadata *Subprograms,
849 Metadata *GlobalVariables, Metadata *ImportedEntities),
850 (SourceLanguage, File, Producer, IsOptimized, Flags,
851 RuntimeVersion, SplitDebugFilename, EmissionKind,
852 EnumTypes, RetainedTypes, Subprograms, GlobalVariables,
855 TempMDCompileUnit clone() const { return cloneImpl(); }
857 unsigned getSourceLanguage() const { return SourceLanguage; }
858 bool isOptimized() const { return IsOptimized; }
859 unsigned getRuntimeVersion() const { return RuntimeVersion; }
860 unsigned getEmissionKind() const { return EmissionKind; }
861 StringRef getProducer() const { return getStringOperand(1); }
862 StringRef getFlags() const { return getStringOperand(2); }
863 StringRef getSplitDebugFilename() const { return getStringOperand(3); }
864 Metadata *getEnumTypes() const { return getOperand(4); }
865 Metadata *getRetainedTypes() const { return getOperand(5); }
866 Metadata *getSubprograms() const { return getOperand(6); }
867 Metadata *getGlobalVariables() const { return getOperand(7); }
868 Metadata *getImportedEntities() const { return getOperand(8); }
870 MDString *getRawProducer() const { return getOperandAs<MDString>(1); }
871 MDString *getRawFlags() const { return getOperandAs<MDString>(2); }
872 MDString *getRawSplitDebugFilename() const {
873 return getOperandAs<MDString>(3);
876 /// \brief Replace arrays.
878 /// If this \a isUniqued() and not \a isResolved(), it will be RAUW'ed and
879 /// deleted on a uniquing collision. In practice, uniquing collisions on \a
880 /// MDCompileUnit should be fairly rare.
882 void replaceSubprograms(MDTuple *N) { replaceOperandWith(6, N); }
883 void replaceGlobalVariables(MDTuple *N) { replaceOperandWith(7, N); }
886 static bool classof(const Metadata *MD) {
887 return MD->getMetadataID() == MDCompileUnitKind;
891 /// \brief Subprogram description.
893 /// TODO: Remove DisplayName. It's always equal to Name.
894 /// TODO: Split up flags.
895 class MDSubprogram : public MDScope {
896 friend class LLVMContextImpl;
902 unsigned VirtualIndex;
908 MDSubprogram(LLVMContext &C, StorageType Storage, unsigned Line,
909 unsigned ScopeLine, unsigned Virtuality, unsigned VirtualIndex,
910 unsigned Flags, bool IsLocalToUnit, bool IsDefinition,
911 bool IsOptimized, ArrayRef<Metadata *> Ops)
912 : MDScope(C, MDSubprogramKind, Storage, dwarf::DW_TAG_subprogram, Ops),
913 Line(Line), ScopeLine(ScopeLine), Virtuality(Virtuality),
914 VirtualIndex(VirtualIndex), Flags(Flags), IsLocalToUnit(IsLocalToUnit),
915 IsDefinition(IsDefinition), IsOptimized(IsOptimized) {}
918 static MDSubprogram *
919 getImpl(LLVMContext &Context, Metadata *Scope, StringRef Name,
920 StringRef LinkageName, Metadata *File, unsigned Line, Metadata *Type,
921 bool IsLocalToUnit, bool IsDefinition, unsigned ScopeLine,
922 Metadata *ContainingType, unsigned Virtuality, unsigned VirtualIndex,
923 unsigned Flags, bool IsOptimized, Metadata *Function,
924 Metadata *TemplateParams, Metadata *Declaration, Metadata *Variables,
925 StorageType Storage, bool ShouldCreate = true) {
926 return getImpl(Context, Scope, getCanonicalMDString(Context, Name),
927 getCanonicalMDString(Context, LinkageName), File, Line, Type,
928 IsLocalToUnit, IsDefinition, ScopeLine, ContainingType,
929 Virtuality, VirtualIndex, Flags, IsOptimized, Function,
930 TemplateParams, Declaration, Variables, Storage,
933 static MDSubprogram *
934 getImpl(LLVMContext &Context, Metadata *Scope, MDString *Name,
935 MDString *LinkageName, Metadata *File, unsigned Line, Metadata *Type,
936 bool IsLocalToUnit, bool IsDefinition, unsigned ScopeLine,
937 Metadata *ContainingType, unsigned Virtuality, unsigned VirtualIndex,
938 unsigned Flags, bool IsOptimized, Metadata *Function,
939 Metadata *TemplateParams, Metadata *Declaration, Metadata *Variables,
940 StorageType Storage, bool ShouldCreate = true);
942 TempMDSubprogram cloneImpl() const {
943 return getTemporary(getContext(), getScope(), getName(), getLinkageName(),
944 getFile(), getLine(), getType(), isLocalToUnit(),
945 isDefinition(), getScopeLine(), getContainingType(),
946 getVirtuality(), getVirtualIndex(), getFlags(),
947 isOptimized(), getFunction(), getTemplateParams(),
948 getDeclaration(), getVariables());
954 (Metadata * Scope, StringRef Name, StringRef LinkageName, Metadata *File,
955 unsigned Line, Metadata *Type, bool IsLocalToUnit, bool IsDefinition,
956 unsigned ScopeLine, Metadata *ContainingType, unsigned Virtuality,
957 unsigned VirtualIndex, unsigned Flags, bool IsOptimized,
958 Metadata *Function = nullptr, Metadata *TemplateParams = nullptr,
959 Metadata *Declaration = nullptr, Metadata *Variables = nullptr),
960 (Scope, Name, LinkageName, File, Line, Type, IsLocalToUnit, IsDefinition,
961 ScopeLine, ContainingType, Virtuality, VirtualIndex, Flags, IsOptimized,
962 Function, TemplateParams, Declaration, Variables))
965 (Metadata * Scope, MDString *Name, MDString *LinkageName, Metadata *File,
966 unsigned Line, Metadata *Type, bool IsLocalToUnit, bool IsDefinition,
967 unsigned ScopeLine, Metadata *ContainingType, unsigned Virtuality,
968 unsigned VirtualIndex, unsigned Flags, bool IsOptimized,
969 Metadata *Function = nullptr, Metadata *TemplateParams = nullptr,
970 Metadata *Declaration = nullptr, Metadata *Variables = nullptr),
971 (Scope, Name, LinkageName, File, Line, Type, IsLocalToUnit, IsDefinition,
972 ScopeLine, ContainingType, Virtuality, VirtualIndex, Flags, IsOptimized,
973 Function, TemplateParams, Declaration, Variables))
975 TempMDSubprogram clone() const { return cloneImpl(); }
978 unsigned getLine() const { return Line; }
979 unsigned getVirtuality() const { return Virtuality; }
980 unsigned getVirtualIndex() const { return VirtualIndex; }
981 unsigned getScopeLine() const { return ScopeLine; }
982 unsigned getFlags() const { return Flags; }
983 bool isLocalToUnit() const { return IsLocalToUnit; }
984 bool isDefinition() const { return IsDefinition; }
985 bool isOptimized() const { return IsOptimized; }
987 Metadata *getScope() const { return getOperand(1); }
989 StringRef getName() const { return getStringOperand(2); }
990 StringRef getDisplayName() const { return getStringOperand(3); }
991 StringRef getLinkageName() const { return getStringOperand(4); }
993 MDString *getRawName() const { return getOperandAs<MDString>(2); }
994 MDString *getRawLinkageName() const { return getOperandAs<MDString>(4); }
996 Metadata *getType() const { return getOperand(5); }
997 Metadata *getContainingType() const { return getOperand(6); }
999 Metadata *getFunction() const { return getOperand(7); }
1000 Metadata *getTemplateParams() const { return getOperand(8); }
1001 Metadata *getDeclaration() const { return getOperand(9); }
1002 Metadata *getVariables() const { return getOperand(10); }
1004 /// \brief Replace the function.
1006 /// If \a isUniqued() and not \a isResolved(), this could node will be
1007 /// RAUW'ed and deleted out from under the caller. Use a \a TrackingMDRef if
1008 /// that's a problem.
1010 void replaceFunction(Function *F);
1011 void replaceFunction(ConstantAsMetadata *MD) { replaceOperandWith(7, MD); }
1012 void replaceFunction(std::nullptr_t) { replaceOperandWith(7, nullptr); }
1015 static bool classof(const Metadata *MD) {
1016 return MD->getMetadataID() == MDSubprogramKind;
1020 class MDLexicalBlockBase : public MDScope {
1022 MDLexicalBlockBase(LLVMContext &C, unsigned ID, StorageType Storage,
1023 ArrayRef<Metadata *> Ops)
1024 : MDScope(C, ID, Storage, dwarf::DW_TAG_lexical_block, Ops) {}
1025 ~MDLexicalBlockBase() {}
1028 Metadata *getScope() const { return getOperand(1); }
1030 static bool classof(const Metadata *MD) {
1031 return MD->getMetadataID() == MDLexicalBlockKind ||
1032 MD->getMetadataID() == MDLexicalBlockFileKind;
1036 class MDLexicalBlock : public MDLexicalBlockBase {
1037 friend class LLVMContextImpl;
1038 friend class MDNode;
1043 MDLexicalBlock(LLVMContext &C, StorageType Storage, unsigned Line,
1044 unsigned Column, ArrayRef<Metadata *> Ops)
1045 : MDLexicalBlockBase(C, MDLexicalBlockKind, Storage, Ops), Line(Line),
1047 ~MDLexicalBlock() {}
1049 static MDLexicalBlock *getImpl(LLVMContext &Context, Metadata *Scope,
1050 Metadata *File, unsigned Line, unsigned Column,
1051 StorageType Storage, bool ShouldCreate = true);
1053 TempMDLexicalBlock cloneImpl() const {
1054 return getTemporary(getContext(), getScope(), getFile(), getLine(),
1059 DEFINE_MDNODE_GET(MDLexicalBlock, (Metadata * Scope, Metadata *File,
1060 unsigned Line, unsigned Column),
1061 (Scope, File, Line, Column))
1063 TempMDLexicalBlock clone() const { return cloneImpl(); }
1065 unsigned getLine() const { return Line; }
1066 unsigned getColumn() const { return Column; }
1068 static bool classof(const Metadata *MD) {
1069 return MD->getMetadataID() == MDLexicalBlockKind;
1073 class MDLexicalBlockFile : public MDLexicalBlockBase {
1074 friend class LLVMContextImpl;
1075 friend class MDNode;
1077 unsigned Discriminator;
1079 MDLexicalBlockFile(LLVMContext &C, StorageType Storage,
1080 unsigned Discriminator, ArrayRef<Metadata *> Ops)
1081 : MDLexicalBlockBase(C, MDLexicalBlockFileKind, Storage, Ops),
1082 Discriminator(Discriminator) {}
1083 ~MDLexicalBlockFile() {}
1085 static MDLexicalBlockFile *getImpl(LLVMContext &Context, Metadata *Scope,
1086 Metadata *File, unsigned Discriminator,
1087 StorageType Storage,
1088 bool ShouldCreate = true);
1090 TempMDLexicalBlockFile cloneImpl() const {
1091 return getTemporary(getContext(), getScope(), getFile(),
1092 getDiscriminator());
1096 DEFINE_MDNODE_GET(MDLexicalBlockFile,
1097 (Metadata * Scope, Metadata *File, unsigned Discriminator),
1098 (Scope, File, Discriminator))
1100 TempMDLexicalBlockFile clone() const { return cloneImpl(); }
1102 unsigned getDiscriminator() const { return Discriminator; }
1104 static bool classof(const Metadata *MD) {
1105 return MD->getMetadataID() == MDLexicalBlockFileKind;
1109 class MDNamespace : public MDScope {
1110 friend class LLVMContextImpl;
1111 friend class MDNode;
1115 MDNamespace(LLVMContext &Context, StorageType Storage, unsigned Line,
1116 ArrayRef<Metadata *> Ops)
1117 : MDScope(Context, MDNamespaceKind, Storage, dwarf::DW_TAG_namespace,
1122 static MDNamespace *getImpl(LLVMContext &Context, Metadata *Scope,
1123 Metadata *File, StringRef Name, unsigned Line,
1124 StorageType Storage, bool ShouldCreate = true) {
1125 return getImpl(Context, Scope, File, getCanonicalMDString(Context, Name),
1126 Line, Storage, ShouldCreate);
1128 static MDNamespace *getImpl(LLVMContext &Context, Metadata *Scope,
1129 Metadata *File, MDString *Name, unsigned Line,
1130 StorageType Storage, bool ShouldCreate = true);
1132 TempMDNamespace cloneImpl() const {
1133 return getTemporary(getContext(), getScope(), getFile(), getName(),
1138 DEFINE_MDNODE_GET(MDNamespace, (Metadata * Scope, Metadata *File,
1139 StringRef Name, unsigned Line),
1140 (Scope, File, Name, Line))
1141 DEFINE_MDNODE_GET(MDNamespace, (Metadata * Scope, Metadata *File,
1142 MDString *Name, unsigned Line),
1143 (Scope, File, Name, Line))
1145 TempMDNamespace clone() const { return cloneImpl(); }
1147 unsigned getLine() const { return Line; }
1148 Metadata *getScope() const { return getOperand(1); }
1149 StringRef getName() const { return getStringOperand(2); }
1151 MDString *getRawName() const { return getOperandAs<MDString>(2); }
1153 static bool classof(const Metadata *MD) {
1154 return MD->getMetadataID() == MDNamespaceKind;
1158 /// \brief Base class for template parameters.
1159 class MDTemplateParameter : public DebugNode {
1161 MDTemplateParameter(LLVMContext &Context, unsigned ID, StorageType Storage,
1162 unsigned Tag, ArrayRef<Metadata *> Ops)
1163 : DebugNode(Context, ID, Storage, Tag, Ops) {}
1164 ~MDTemplateParameter() {}
1167 StringRef getName() const { return getStringOperand(0); }
1168 Metadata *getType() const { return getOperand(1); }
1170 MDString *getRawName() const { return getOperandAs<MDString>(0); }
1172 static bool classof(const Metadata *MD) {
1173 return MD->getMetadataID() == MDTemplateTypeParameterKind ||
1174 MD->getMetadataID() == MDTemplateValueParameterKind;
1178 class MDTemplateTypeParameter : public MDTemplateParameter {
1179 friend class LLVMContextImpl;
1180 friend class MDNode;
1182 MDTemplateTypeParameter(LLVMContext &Context, StorageType Storage,
1183 ArrayRef<Metadata *> Ops)
1184 : MDTemplateParameter(Context, MDTemplateTypeParameterKind, Storage,
1185 dwarf::DW_TAG_template_type_parameter, Ops) {}
1186 ~MDTemplateTypeParameter() {}
1188 static MDTemplateTypeParameter *getImpl(LLVMContext &Context, StringRef Name,
1189 Metadata *Type, StorageType Storage,
1190 bool ShouldCreate = true) {
1191 return getImpl(Context, getCanonicalMDString(Context, Name), Type, Storage,
1194 static MDTemplateTypeParameter *getImpl(LLVMContext &Context, MDString *Name,
1195 Metadata *Type, StorageType Storage,
1196 bool ShouldCreate = true);
1198 TempMDTemplateTypeParameter cloneImpl() const {
1199 return getTemporary(getContext(), getName(), getType());
1203 DEFINE_MDNODE_GET(MDTemplateTypeParameter, (StringRef Name, Metadata *Type),
1205 DEFINE_MDNODE_GET(MDTemplateTypeParameter, (MDString * Name, Metadata *Type),
1208 TempMDTemplateTypeParameter clone() const { return cloneImpl(); }
1210 static bool classof(const Metadata *MD) {
1211 return MD->getMetadataID() == MDTemplateTypeParameterKind;
1215 class MDTemplateValueParameter : public MDTemplateParameter {
1216 friend class LLVMContextImpl;
1217 friend class MDNode;
1219 MDTemplateValueParameter(LLVMContext &Context, StorageType Storage,
1220 unsigned Tag, ArrayRef<Metadata *> Ops)
1221 : MDTemplateParameter(Context, MDTemplateValueParameterKind, Storage, Tag,
1223 ~MDTemplateValueParameter() {}
1225 static MDTemplateValueParameter *getImpl(LLVMContext &Context, unsigned Tag,
1226 StringRef Name, Metadata *Type,
1227 Metadata *Value, StorageType Storage,
1228 bool ShouldCreate = true) {
1229 return getImpl(Context, Tag, getCanonicalMDString(Context, Name), Type,
1230 Value, Storage, ShouldCreate);
1232 static MDTemplateValueParameter *getImpl(LLVMContext &Context, unsigned Tag,
1233 MDString *Name, Metadata *Type,
1234 Metadata *Value, StorageType Storage,
1235 bool ShouldCreate = true);
1237 TempMDTemplateValueParameter cloneImpl() const {
1238 return getTemporary(getContext(), getTag(), getName(), getType(),
1243 DEFINE_MDNODE_GET(MDTemplateValueParameter, (unsigned Tag, StringRef Name,
1244 Metadata *Type, Metadata *Value),
1245 (Tag, Name, Type, Value))
1246 DEFINE_MDNODE_GET(MDTemplateValueParameter, (unsigned Tag, MDString *Name,
1247 Metadata *Type, Metadata *Value),
1248 (Tag, Name, Type, Value))
1250 TempMDTemplateValueParameter clone() const { return cloneImpl(); }
1252 Metadata *getValue() const { return getOperand(2); }
1254 static bool classof(const Metadata *MD) {
1255 return MD->getMetadataID() == MDTemplateValueParameterKind;
1259 /// \brief Base class for variables.
1261 /// TODO: Hardcode to DW_TAG_variable.
1262 class MDVariable : public DebugNode {
1266 MDVariable(LLVMContext &C, unsigned ID, StorageType Storage, unsigned Tag,
1267 unsigned Line, ArrayRef<Metadata *> Ops)
1268 : DebugNode(C, ID, Storage, Tag, Ops), Line(Line) {}
1272 unsigned getLine() const { return Line; }
1273 Metadata *getScope() const { return getOperand(0); }
1274 StringRef getName() const { return getStringOperand(1); }
1275 Metadata *getFile() const { return getOperand(2); }
1276 Metadata *getType() const { return getOperand(3); }
1278 MDString *getRawName() const { return getOperandAs<MDString>(1); }
1280 static bool classof(const Metadata *MD) {
1281 return MD->getMetadataID() == MDLocalVariableKind ||
1282 MD->getMetadataID() == MDGlobalVariableKind;
1286 /// \brief Global variables.
1288 /// TODO: Remove DisplayName. It's always equal to Name.
1289 class MDGlobalVariable : public MDVariable {
1290 friend class LLVMContextImpl;
1291 friend class MDNode;
1296 MDGlobalVariable(LLVMContext &C, StorageType Storage, unsigned Line,
1297 bool IsLocalToUnit, bool IsDefinition,
1298 ArrayRef<Metadata *> Ops)
1299 : MDVariable(C, MDGlobalVariableKind, Storage, dwarf::DW_TAG_variable,
1301 IsLocalToUnit(IsLocalToUnit), IsDefinition(IsDefinition) {}
1302 ~MDGlobalVariable() {}
1304 static MDGlobalVariable *
1305 getImpl(LLVMContext &Context, Metadata *Scope, StringRef Name,
1306 StringRef LinkageName, Metadata *File, unsigned Line, Metadata *Type,
1307 bool IsLocalToUnit, bool IsDefinition, Metadata *Variable,
1308 Metadata *StaticDataMemberDeclaration, StorageType Storage,
1309 bool ShouldCreate = true) {
1310 return getImpl(Context, Scope, getCanonicalMDString(Context, Name),
1311 getCanonicalMDString(Context, LinkageName), File, Line, Type,
1312 IsLocalToUnit, IsDefinition, Variable,
1313 StaticDataMemberDeclaration, Storage, ShouldCreate);
1315 static MDGlobalVariable *
1316 getImpl(LLVMContext &Context, Metadata *Scope, MDString *Name,
1317 MDString *LinkageName, Metadata *File, unsigned Line, Metadata *Type,
1318 bool IsLocalToUnit, bool IsDefinition, Metadata *Variable,
1319 Metadata *StaticDataMemberDeclaration, StorageType Storage,
1320 bool ShouldCreate = true);
1322 TempMDGlobalVariable cloneImpl() const {
1323 return getTemporary(getContext(), getScope(), getName(), getLinkageName(),
1324 getFile(), getLine(), getType(), isLocalToUnit(),
1325 isDefinition(), getVariable(),
1326 getStaticDataMemberDeclaration());
1330 DEFINE_MDNODE_GET(MDGlobalVariable,
1331 (Metadata * Scope, StringRef Name, StringRef LinkageName,
1332 Metadata *File, unsigned Line, Metadata *Type,
1333 bool IsLocalToUnit, bool IsDefinition, Metadata *Variable,
1334 Metadata *StaticDataMemberDeclaration),
1335 (Scope, Name, LinkageName, File, Line, Type, IsLocalToUnit,
1336 IsDefinition, Variable, StaticDataMemberDeclaration))
1337 DEFINE_MDNODE_GET(MDGlobalVariable,
1338 (Metadata * Scope, MDString *Name, MDString *LinkageName,
1339 Metadata *File, unsigned Line, Metadata *Type,
1340 bool IsLocalToUnit, bool IsDefinition, Metadata *Variable,
1341 Metadata *StaticDataMemberDeclaration),
1342 (Scope, Name, LinkageName, File, Line, Type, IsLocalToUnit,
1343 IsDefinition, Variable, StaticDataMemberDeclaration))
1345 TempMDGlobalVariable clone() const { return cloneImpl(); }
1347 bool isLocalToUnit() const { return IsLocalToUnit; }
1348 bool isDefinition() const { return IsDefinition; }
1349 StringRef getDisplayName() const { return getStringOperand(4); }
1350 StringRef getLinkageName() const { return getStringOperand(5); }
1351 Metadata *getVariable() const { return getOperand(6); }
1352 Metadata *getStaticDataMemberDeclaration() const { return getOperand(7); }
1354 MDString *getRawLinkageName() const { return getOperandAs<MDString>(5); }
1356 static bool classof(const Metadata *MD) {
1357 return MD->getMetadataID() == MDGlobalVariableKind;
1361 /// \brief Local variable.
1363 /// TODO: Split between arguments and otherwise.
1364 /// TODO: Use \c DW_TAG_variable instead of fake tags.
1365 /// TODO: Split up flags.
1366 class MDLocalVariable : public MDVariable {
1367 friend class LLVMContextImpl;
1368 friend class MDNode;
1373 MDLocalVariable(LLVMContext &C, StorageType Storage, unsigned Tag,
1374 unsigned Line, unsigned Arg, unsigned Flags,
1375 ArrayRef<Metadata *> Ops)
1376 : MDVariable(C, MDLocalVariableKind, Storage, Tag, Line, Ops), Arg(Arg),
1378 ~MDLocalVariable() {}
1380 static MDLocalVariable *getImpl(LLVMContext &Context, unsigned Tag,
1381 Metadata *Scope, StringRef Name,
1382 Metadata *File, unsigned Line, Metadata *Type,
1383 unsigned Arg, unsigned Flags,
1384 Metadata *InlinedAt, StorageType Storage,
1385 bool ShouldCreate = true) {
1386 return getImpl(Context, Tag, Scope, getCanonicalMDString(Context, Name),
1387 File, Line, Type, Arg, Flags, InlinedAt, Storage,
1390 static MDLocalVariable *getImpl(LLVMContext &Context, unsigned Tag,
1391 Metadata *Scope, MDString *Name,
1392 Metadata *File, unsigned Line, Metadata *Type,
1393 unsigned Arg, unsigned Flags,
1394 Metadata *InlinedAt, StorageType Storage,
1395 bool ShouldCreate = true);
1397 TempMDLocalVariable cloneImpl() const {
1398 return getTemporary(getContext(), getTag(), getScope(), getName(),
1399 getFile(), getLine(), getType(), getArg(), getFlags(),
1404 DEFINE_MDNODE_GET(MDLocalVariable,
1405 (unsigned Tag, Metadata *Scope, StringRef Name,
1406 Metadata *File, unsigned Line, Metadata *Type,
1407 unsigned Arg, unsigned Flags,
1408 Metadata *InlinedAt = nullptr),
1409 (Tag, Scope, Name, File, Line, Type, Arg, Flags, InlinedAt))
1410 DEFINE_MDNODE_GET(MDLocalVariable,
1411 (unsigned Tag, Metadata *Scope, MDString *Name,
1412 Metadata *File, unsigned Line, Metadata *Type,
1413 unsigned Arg, unsigned Flags,
1414 Metadata *InlinedAt = nullptr),
1415 (Tag, Scope, Name, File, Line, Type, Arg, Flags, InlinedAt))
1417 TempMDLocalVariable clone() const { return cloneImpl(); }
1419 unsigned getArg() const { return Arg; }
1420 unsigned getFlags() const { return Flags; }
1421 Metadata *getInlinedAt() const { return getOperand(4); }
1423 static bool classof(const Metadata *MD) {
1424 return MD->getMetadataID() == MDLocalVariableKind;
1428 /// \brief DWARF expression.
1430 /// TODO: Co-allocate the expression elements.
1431 /// TODO: Drop fake DW_TAG_expression and separate from DebugNode.
1432 /// TODO: Separate from MDNode, or otherwise drop Distinct and Temporary
1434 class MDExpression : public DebugNode {
1435 friend class LLVMContextImpl;
1436 friend class MDNode;
1438 std::vector<uint64_t> Elements;
1440 MDExpression(LLVMContext &C, StorageType Storage, ArrayRef<uint64_t> Elements)
1441 : DebugNode(C, MDExpressionKind, Storage, dwarf::DW_TAG_expression, None),
1442 Elements(Elements.begin(), Elements.end()) {}
1445 static MDExpression *getImpl(LLVMContext &Context,
1446 ArrayRef<uint64_t> Elements, StorageType Storage,
1447 bool ShouldCreate = true);
1449 TempMDExpression cloneImpl() const {
1450 return getTemporary(getContext(), getElements());
1454 DEFINE_MDNODE_GET(MDExpression, (ArrayRef<uint64_t> Elements), (Elements))
1456 TempMDExpression clone() const { return cloneImpl(); }
1458 ArrayRef<uint64_t> getElements() const { return Elements; }
1460 unsigned getNumElements() const { return Elements.size(); }
1461 uint64_t getElement(unsigned I) const {
1462 assert(I < Elements.size() && "Index out of range");
1466 typedef ArrayRef<uint64_t>::iterator element_iterator;
1467 element_iterator elements_begin() const { return getElements().begin(); }
1468 element_iterator elements_end() const { return getElements().end(); }
1470 /// \brief A lightweight wrapper around an expression operand.
1472 /// TODO: Store arguments directly and change \a MDExpression to store a
1478 explicit ExprOperand(const uint64_t *Op) : Op(Op) {}
1480 const uint64_t *get() const { return Op; }
1482 /// \brief Get the operand code.
1483 uint64_t getOp() const { return *Op; }
1485 /// \brief Get an argument to the operand.
1487 /// Never returns the operand itself.
1488 uint64_t getArg(unsigned I) const { return Op[I + 1]; }
1490 unsigned getNumArgs() const { return getSize() - 1; }
1492 /// \brief Return the size of the operand.
1494 /// Return the number of elements in the operand (1 + args).
1495 unsigned getSize() const;
1498 /// \brief An iterator for expression operands.
1499 class expr_op_iterator
1500 : public std::iterator<std::input_iterator_tag, ExprOperand> {
1504 explicit expr_op_iterator(element_iterator I) : Op(I) {}
1506 element_iterator getBase() const { return Op.get(); }
1507 const ExprOperand &operator*() const { return Op; }
1508 const ExprOperand *operator->() const { return &Op; }
1510 expr_op_iterator &operator++() {
1514 expr_op_iterator operator++(int) {
1515 expr_op_iterator T(*this);
1520 bool operator==(const expr_op_iterator &X) const {
1521 return getBase() == X.getBase();
1523 bool operator!=(const expr_op_iterator &X) const {
1524 return getBase() != X.getBase();
1528 void increment() { Op = ExprOperand(getBase() + Op.getSize()); }
1531 /// \brief Visit the elements via ExprOperand wrappers.
1533 /// These range iterators visit elements through \a ExprOperand wrappers.
1534 /// This is not guaranteed to be a valid range unless \a isValid() gives \c
1537 /// \pre \a isValid() gives \c true.
1539 expr_op_iterator expr_op_begin() const {
1540 return expr_op_iterator(elements_begin());
1542 expr_op_iterator expr_op_end() const {
1543 return expr_op_iterator(elements_end());
1547 bool isValid() const;
1549 static bool classof(const Metadata *MD) {
1550 return MD->getMetadataID() == MDExpressionKind;
1554 class MDObjCProperty : public DebugNode {
1555 friend class LLVMContextImpl;
1556 friend class MDNode;
1559 unsigned Attributes;
1561 MDObjCProperty(LLVMContext &C, StorageType Storage, unsigned Line,
1562 unsigned Attributes, ArrayRef<Metadata *> Ops)
1563 : DebugNode(C, MDObjCPropertyKind, Storage, dwarf::DW_TAG_APPLE_property,
1565 Line(Line), Attributes(Attributes) {}
1566 ~MDObjCProperty() {}
1568 static MDObjCProperty *
1569 getImpl(LLVMContext &Context, StringRef Name, Metadata *File, unsigned Line,
1570 StringRef GetterName, StringRef SetterName, unsigned Attributes,
1571 Metadata *Type, StorageType Storage, bool ShouldCreate = true) {
1572 return getImpl(Context, getCanonicalMDString(Context, Name), File, Line,
1573 getCanonicalMDString(Context, GetterName),
1574 getCanonicalMDString(Context, SetterName), Attributes, Type,
1575 Storage, ShouldCreate);
1577 static MDObjCProperty *getImpl(LLVMContext &Context, MDString *Name,
1578 Metadata *File, unsigned Line,
1579 MDString *GetterName, MDString *SetterName,
1580 unsigned Attributes, Metadata *Type,
1581 StorageType Storage, bool ShouldCreate = true);
1583 TempMDObjCProperty cloneImpl() const {
1584 return getTemporary(getContext(), getName(), getFile(), getLine(),
1585 getGetterName(), getSetterName(), getAttributes(),
1590 DEFINE_MDNODE_GET(MDObjCProperty,
1591 (StringRef Name, Metadata *File, unsigned Line,
1592 StringRef GetterName, StringRef SetterName,
1593 unsigned Attributes, Metadata *Type),
1594 (Name, File, Line, GetterName, SetterName, Attributes,
1596 DEFINE_MDNODE_GET(MDObjCProperty,
1597 (MDString * Name, Metadata *File, unsigned Line,
1598 MDString *GetterName, MDString *SetterName,
1599 unsigned Attributes, Metadata *Type),
1600 (Name, File, Line, GetterName, SetterName, Attributes,
1603 TempMDObjCProperty clone() const { return cloneImpl(); }
1605 unsigned getLine() const { return Line; }
1606 unsigned getAttributes() const { return Attributes; }
1607 StringRef getName() const { return getStringOperand(0); }
1608 Metadata *getFile() const { return getOperand(1); }
1609 StringRef getGetterName() const { return getStringOperand(2); }
1610 StringRef getSetterName() const { return getStringOperand(3); }
1611 Metadata *getType() const { return getOperand(4); }
1613 MDString *getRawName() const { return getOperandAs<MDString>(0); }
1614 MDString *getRawGetterName() const { return getOperandAs<MDString>(2); }
1615 MDString *getRawSetterName() const { return getOperandAs<MDString>(3); }
1617 static bool classof(const Metadata *MD) {
1618 return MD->getMetadataID() == MDObjCPropertyKind;
1622 class MDImportedEntity : public DebugNode {
1623 friend class LLVMContextImpl;
1624 friend class MDNode;
1628 MDImportedEntity(LLVMContext &C, StorageType Storage, unsigned Tag,
1629 unsigned Line, ArrayRef<Metadata *> Ops)
1630 : DebugNode(C, MDImportedEntityKind, Storage, Tag, Ops), Line(Line) {}
1631 ~MDImportedEntity() {}
1633 static MDImportedEntity *getImpl(LLVMContext &Context, unsigned Tag,
1634 Metadata *Scope, Metadata *Entity,
1635 unsigned Line, StringRef Name,
1636 StorageType Storage,
1637 bool ShouldCreate = true) {
1638 return getImpl(Context, Tag, Scope, Entity, Line,
1639 getCanonicalMDString(Context, Name), Storage, ShouldCreate);
1641 static MDImportedEntity *getImpl(LLVMContext &Context, unsigned Tag,
1642 Metadata *Scope, Metadata *Entity,
1643 unsigned Line, MDString *Name,
1644 StorageType Storage,
1645 bool ShouldCreate = true);
1647 TempMDImportedEntity cloneImpl() const {
1648 return getTemporary(getContext(), getTag(), getScope(), getEntity(),
1649 getLine(), getName());
1653 DEFINE_MDNODE_GET(MDImportedEntity,
1654 (unsigned Tag, Metadata *Scope, Metadata *Entity,
1655 unsigned Line, StringRef Name = ""),
1656 (Tag, Scope, Entity, Line, Name))
1657 DEFINE_MDNODE_GET(MDImportedEntity,
1658 (unsigned Tag, Metadata *Scope, Metadata *Entity,
1659 unsigned Line, MDString *Name),
1660 (Tag, Scope, Entity, Line, Name))
1662 TempMDImportedEntity clone() const { return cloneImpl(); }
1664 unsigned getLine() const { return Line; }
1665 Metadata *getScope() const { return getOperand(0); }
1666 Metadata *getEntity() const { return getOperand(1); }
1667 StringRef getName() const { return getStringOperand(2); }
1669 MDString *getRawName() const { return getOperandAs<MDString>(2); }
1671 static bool classof(const Metadata *MD) {
1672 return MD->getMetadataID() == MDImportedEntityKind;
1676 } // end namespace llvm
1678 #undef DEFINE_MDNODE_GET_UNPACK_IMPL
1679 #undef DEFINE_MDNODE_GET_UNPACK
1680 #undef DEFINE_MDNODE_GET