LLVM 22.0.0git
llvm::DISubprogram Class Reference

Subprogram description. Uses SubclassData1. More...

#include "llvm/IR/DebugInfoMetadata.h"

Inheritance diagram for llvm::DISubprogram:
[legend]

Public Types

enum  DISPFlags : uint32_t { SPFlagNonvirtual = SPFlagZero , SPFlagVirtuality = SPFlagVirtual | SPFlagPureVirtual }
 Debug info subprogram flags. More...
Public Types inherited from llvm::DINode
enum  DIFlags : uint32_t { FlagAccessibility = FlagPrivate | FlagProtected | FlagPublic , FlagPtrToMemberRep }
 Debug info flags. More...
Public Types inherited from llvm::MDNode
using op_iterator = const MDOperand *
using op_range = iterator_range<op_iterator>

Public Member Functions

 DEFINE_MDNODE_GET (DISubprogram,(DIScope *Scope, StringRef Name, StringRef LinkageName, DIFile *File, unsigned Line, DISubroutineType *Type, unsigned ScopeLine, DIType *ContainingType, unsigned VirtualIndex, int ThisAdjustment, DIFlags Flags, DISPFlags SPFlags, DICompileUnit *Unit, DITemplateParameterArray TemplateParams=nullptr, DISubprogram *Declaration=nullptr, DINodeArray RetainedNodes=nullptr, DITypeArray ThrownTypes=nullptr, DINodeArray Annotations=nullptr, StringRef TargetFuncName="", bool UsesKeyInstructions=false),(Scope, Name, LinkageName, File, Line, Type, ScopeLine, ContainingType, VirtualIndex, ThisAdjustment, Flags, SPFlags, Unit, TemplateParams, Declaration, RetainedNodes, ThrownTypes, Annotations, TargetFuncName, UsesKeyInstructions)) DEFINE_MDNODE_GET(DISubprogram
Public Member Functions inherited from llvm::DILocalScope
LLVM_ABI DISubprogramgetSubprogram () const
 Get the subprogram for this scope.
LLVM_ABI DILocalScopegetNonLexicalBlockFileScope () const
 Get the first non DILexicalBlockFile scope of this scope.
Public Member Functions inherited from llvm::DIScope
DIFilegetFile () const
StringRef getFilename () const
StringRef getDirectory () const
std::optional< StringRefgetSource () const
LLVM_ABI StringRef getName () const
LLVM_ABI DIScopegetScope () const
MetadatagetRawFile () const
 Return the raw underlying file.
Public Member Functions inherited from llvm::DINode
LLVM_ABI dwarf::Tag getTag () const
Public Member Functions inherited from llvm::MDNode
 MDNode (const MDNode &)=delete
void operator= (const MDNode &)=delete
void * operator new (size_t)=delete
LLVM_ABI TempMDNode clone () const
 Create a (temporary) clone of this.
LLVMContextgetContext () const
LLVM_ABI void replaceOperandWith (unsigned I, Metadata *New)
 Replace a specific operand.
bool isResolved () const
 Check if node is fully resolved.
bool isUniqued () const
bool isDistinct () const
bool isTemporary () const
bool isReplaceable () const
bool isAlwaysReplaceable () const
bool hasGeneralizedMDString ()
 Check if this is a valid generalized type metadata node.
unsigned getNumTemporaryUses () const
void replaceAllUsesWith (Metadata *MD)
 RAUW a temporary.
LLVM_ABI void resolveCycles ()
 Resolve cycles.
LLVM_ABI void resolve ()
 Resolve a unique, unresolved node.
op_iterator op_begin () const
op_iterator op_end () const
ArrayRef< MDOperandoperands () const
const MDOperandgetOperand (unsigned I) const
unsigned getNumOperands () const
 Return number of MDNode operands.
LLVM_ABI bool isTBAAVtableAccess () const
 Check whether MDNode is a vtable access.
LLVM_ABI void printTree (raw_ostream &OS, const Module *M=nullptr) const
 Print in tree shape.
LLVM_ABI void printTree (raw_ostream &OS, ModuleSlotTracker &MST, const Module *M=nullptr) const
LLVM_ABI void dumpTree () const
 User-friendly dump in tree shape.
LLVM_ABI void dumpTree (const Module *M) const

Static Public Member Functions

static LLVM_ABI DISPFlags getFlag (StringRef Flag)
static LLVM_ABI StringRef getFlagString (DISPFlags Flag)
static LLVM_ABI DISPFlags splitFlags (DISPFlags Flags, SmallVectorImpl< DISPFlags > &SplitFlags)
 Split up a flags bitfield for easier printing.
static LLVM_ABI DISPFlags toSPFlags (bool IsLocalToUnit, bool IsDefinition, bool IsOptimized, unsigned Virtuality=SPFlagNonvirtual, bool IsMainSubprogram=false)
static bool classof (const Metadata *MD)
Static Public Member Functions inherited from llvm::DILocalScope
static LLVM_ABI DILocalScopecloneScopeForSubprogram (DILocalScope &RootScope, DISubprogram &NewSP, LLVMContext &Ctx, DenseMap< const MDNode *, MDNode * > &Cache)
 Traverses the scope chain rooted at RootScope until it hits a Subprogram, recreating the chain with "NewSP" instead.
static bool classof (const Metadata *MD)
Static Public Member Functions inherited from llvm::DIScope
static bool classof (const Metadata *MD)
Static Public Member Functions inherited from llvm::DINode
static LLVM_ABI DIFlags getFlag (StringRef Flag)
static LLVM_ABI StringRef getFlagString (DIFlags Flag)
static LLVM_ABI DIFlags splitFlags (DIFlags Flags, SmallVectorImpl< DIFlags > &SplitFlags)
 Split up a flags bitfield.
static bool classof (const Metadata *MD)
Static Public Member Functions inherited from llvm::MDNode
static MDTupleget (LLVMContext &Context, ArrayRef< Metadata * > MDs)
static MDTuplegetIfExists (LLVMContext &Context, ArrayRef< Metadata * > MDs)
static MDTuplegetDistinct (LLVMContext &Context, ArrayRef< Metadata * > MDs)
static TempMDTuple getTemporary (LLVMContext &Context, ArrayRef< Metadata * > MDs)
static LLVM_ABI void deleteTemporary (MDNode *N)
 Deallocate a node created by getTemporary.
template<class T>
static std::enable_if_t< std::is_base_of< MDNode, T >::value, T * > replaceWithPermanent (std::unique_ptr< T, TempMDNodeDeleter > N)
 Replace a temporary node with a permanent one.
template<class T>
static std::enable_if_t< std::is_base_of< MDNode, T >::value, T * > replaceWithUniqued (std::unique_ptr< T, TempMDNodeDeleter > N)
 Replace a temporary node with a uniqued one.
template<class T>
static std::enable_if_t< std::is_base_of< MDNode, T >::value, T * > replaceWithDistinct (std::unique_ptr< T, TempMDNodeDeleter > N)
 Replace a temporary node with a distinct one.
static bool classof (const Metadata *MD)
 Methods for support type inquiry through isa, cast, and dyn_cast:
static LLVM_ABI MDNodeconcatenate (MDNode *A, MDNode *B)
 Methods for metadata merging.
static LLVM_ABI MDNodeintersect (MDNode *A, MDNode *B)
static LLVM_ABI MDNodegetMostGenericTBAA (MDNode *A, MDNode *B)
static LLVM_ABI MDNodegetMostGenericFPMath (MDNode *A, MDNode *B)
static LLVM_ABI MDNodegetMostGenericRange (MDNode *A, MDNode *B)
static LLVM_ABI MDNodegetMostGenericNoaliasAddrspace (MDNode *A, MDNode *B)
static LLVM_ABI MDNodegetMostGenericAliasScope (MDNode *A, MDNode *B)
static LLVM_ABI MDNodegetMostGenericAlignmentOrDereferenceable (MDNode *A, MDNode *B)
static LLVM_ABI MDNodegetMergedProfMetadata (MDNode *A, MDNode *B, const Instruction *AInstr, const Instruction *BInstr)
 Merge !prof metadata from two instructions.
static LLVM_ABI MDNodegetMergedMemProfMetadata (MDNode *A, MDNode *B)
static LLVM_ABI MDNodegetMergedCallsiteMetadata (MDNode *A, MDNode *B)
static LLVM_ABI MDNodegetMergedCalleeTypeMetadata (const MDNode *A, const MDNode *B)

Public Attributes

MetadataScope
Metadata MDStringName
Metadata MDString MDStringLinkageName
Metadata MDString MDString MetadataFile
Metadata MDString MDString Metadata unsigned Line
Metadata MDString MDString Metadata unsigned MetadataType
Metadata MDString MDString Metadata unsigned Metadata unsigned ScopeLine
Metadata MDString MDString Metadata unsigned Metadata unsigned MetadataContainingType
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned VirtualIndex
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int ThisAdjustment
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int DIFlags Flags
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int DIFlags DISPFlags SPFlags
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int DIFlags DISPFlags MetadataUnit
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int DIFlags DISPFlags Metadata MetadataTemplateParams = nullptr
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int DIFlags DISPFlags Metadata Metadata MetadataDeclaration = nullptr
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int DIFlags DISPFlags Metadata Metadata Metadata MetadataRetainedNodes = nullptr
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int DIFlags DISPFlags Metadata Metadata Metadata Metadata MetadataThrownTypes = nullptr
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int DIFlags DISPFlags Metadata Metadata Metadata Metadata Metadata MetadataAnnotations = nullptr
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int DIFlags DISPFlags Metadata Metadata Metadata Metadata Metadata Metadata MDStringTargetFuncName = nullptr
Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int DIFlags DISPFlags Metadata Metadata Metadata Metadata Metadata Metadata MDString bool UsesKeyInstructions

Friends

class LLVMContextImpl
class MDNode

Additional Inherited Members

Protected Types inherited from llvm::MDNode
using mutable_op_range = iterator_range<MDOperand *>
 Active type of storage. More...
Protected Member Functions inherited from llvm::DILocalScope
 DILocalScope (LLVMContext &C, unsigned ID, StorageType Storage, unsigned Tag, ArrayRef< Metadata * > Ops)
 ~DILocalScope ()=default
Protected Member Functions inherited from llvm::DIScope
 DIScope (LLVMContext &C, unsigned ID, StorageType Storage, unsigned Tag, ArrayRef< Metadata * > Ops)
 ~DIScope ()=default
Protected Member Functions inherited from llvm::DINode
 DINode (LLVMContext &C, unsigned ID, StorageType Storage, unsigned Tag, ArrayRef< Metadata * > Ops1, ArrayRef< Metadata * > Ops2={})
 ~DINode ()=default
template<class Ty>
Ty * getOperandAs (unsigned I) const
StringRef getStringOperand (unsigned I) const
void setTag (unsigned Tag)
 Allow subclasses to mutate the tag.
Protected Member Functions inherited from llvm::MDNode
LLVM_ABI MDNode (LLVMContext &Context, unsigned ID, StorageType Storage, ArrayRef< Metadata * > Ops1, ArrayRef< Metadata * > Ops2={})
 ~MDNode ()=default
LLVM_ABI void * operator new (size_t Size, size_t NumOps, StorageType Storage)
LLVM_ABI void operator delete (void *Mem)
void operator delete (void *, unsigned)
 Required by std, but never called.
void operator delete (void *, unsigned, bool)
 Required by std, but never called.
LLVM_ABI void dropAllReferences ()
MDOperandmutable_begin ()
MDOperandmutable_end ()
mutable_op_range mutable_operands ()
LLVM_ABI void setOperand (unsigned I, Metadata *New)
 Set an operand.
unsigned getNumUnresolved () const
void setNumUnresolved (unsigned N)
LLVM_ABI void storeDistinctInContext ()
void resize (size_t NumOps)
 Resize the node to hold NumOps operands.
Static Protected Member Functions inherited from llvm::DINode
static MDStringgetCanonicalMDString (LLVMContext &Context, StringRef S)
Static Protected Member Functions inherited from llvm::MDNode
template<class T, class StoreT>
static TstoreImpl (T *N, StorageType Storage, StoreT &Store)
template<class T>
static TstoreImpl (T *N, StorageType Storage)

Detailed Description

Subprogram description. Uses SubclassData1.

Definition at line 2220 of file DebugInfoMetadata.h.

Member Enumeration Documentation

◆ DISPFlags

Debug info subprogram flags.

Enumerator
SPFlagNonvirtual 
SPFlagVirtuality 

Definition at line 2235 of file DebugInfoMetadata.h.

Member Function Documentation

◆ classof()

bool llvm::DISubprogram::classof ( const Metadata * MD)
inlinestatic

Definition at line 2494 of file DebugInfoMetadata.h.

References llvm::Metadata::getMetadataID().

◆ DEFINE_MDNODE_GET()

◆ getFlag()

DISubprogram::DISPFlags DISubprogram::getFlag ( StringRef Flag)
static

◆ getFlagString()

StringRef DISubprogram::getFlagString ( DISPFlags Flag)
static

Definition at line 1349 of file DebugInfoMetadata.cpp.

References SPFlagVirtuality.

◆ splitFlags()

DISubprogram::DISPFlags DISubprogram::splitFlags ( DISPFlags Flags,
SmallVectorImpl< DISPFlags > & SplitFlags )
static

Split up a flags bitfield for easier printing.

Split Flags into SplitFlags, a vector of its components. Returns any remaining (unrecognized) bits.

Definition at line 1363 of file DebugInfoMetadata.cpp.

◆ toSPFlags()

DISubprogram::DISPFlags DISubprogram::toSPFlags ( bool IsLocalToUnit,
bool IsDefinition,
bool IsOptimized,
unsigned Virtuality = SPFlagNonvirtual,
bool IsMainSubprogram = false )
static

Definition at line 1288 of file DebugInfoMetadata.cpp.

References SPFlagVirtuality.

Referenced by pack_into_DISPFlags().

◆ LLVMContextImpl

friend class LLVMContextImpl
friend

Definition at line 2221 of file DebugInfoMetadata.h.

References LLVMContextImpl.

Referenced by LLVMContextImpl.

◆ MDNode

friend class MDNode
friend

Definition at line 2222 of file DebugInfoMetadata.h.

References MDNode.

Referenced by MDNode.

Member Data Documentation

◆ Annotations

◆ ContainingType

Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata* llvm::DISubprogram::ContainingType

Definition at line 2330 of file DebugInfoMetadata.h.

Referenced by DEFINE_MDNODE_GET().

◆ Declaration

Definition at line 2332 of file DebugInfoMetadata.h.

Referenced by DEFINE_MDNODE_GET().

◆ File

Metadata MDString MDString Metadata* llvm::DISubprogram::File

Definition at line 2328 of file DebugInfoMetadata.h.

Referenced by DEFINE_MDNODE_GET().

◆ Flags

Definition at line 2331 of file DebugInfoMetadata.h.

◆ Line

Metadata MDString MDString Metadata unsigned llvm::DISubprogram::Line

Definition at line 2329 of file DebugInfoMetadata.h.

◆ LinkageName

Metadata MDString MDString* llvm::DISubprogram::LinkageName

Definition at line 2328 of file DebugInfoMetadata.h.

Referenced by DEFINE_MDNODE_GET().

◆ Name

Metadata MDString* llvm::DISubprogram::Name

Definition at line 2328 of file DebugInfoMetadata.h.

Referenced by DEFINE_MDNODE_GET().

◆ RetainedNodes

Definition at line 2333 of file DebugInfoMetadata.h.

Referenced by DEFINE_MDNODE_GET().

◆ Scope

Metadata* llvm::DISubprogram::Scope

Definition at line 2328 of file DebugInfoMetadata.h.

Referenced by DEFINE_MDNODE_GET().

◆ ScopeLine

Metadata MDString MDString Metadata unsigned Metadata unsigned llvm::DISubprogram::ScopeLine

Definition at line 2329 of file DebugInfoMetadata.h.

◆ SPFlags

Definition at line 2331 of file DebugInfoMetadata.h.

◆ TargetFuncName

◆ TemplateParams

Definition at line 2332 of file DebugInfoMetadata.h.

Referenced by DEFINE_MDNODE_GET().

◆ ThisAdjustment

Metadata MDString MDString Metadata unsigned Metadata unsigned Metadata unsigned int llvm::DISubprogram::ThisAdjustment

Definition at line 2330 of file DebugInfoMetadata.h.

◆ ThrownTypes

◆ Type

Metadata MDString MDString Metadata unsigned Metadata* llvm::DISubprogram::Type

Definition at line 2329 of file DebugInfoMetadata.h.

Referenced by DEFINE_MDNODE_GET().

◆ Unit

◆ UsesKeyInstructions

◆ VirtualIndex

Definition at line 2330 of file DebugInfoMetadata.h.


The documentation for this class was generated from the following files: