LLVM: llvm::Module Class Reference (original) (raw)

A Module instance is used to store all the information related to an LLVM module. More...

#include "[llvm/IR/Module.h](IR%5F2Module%5F8h%5Fsource.html)"

Classes
class debug_compile_units_iterator
An iterator for DICompileUnits that skips those marked NoDebug. More...
struct ModuleFlagEntry
Public Member Functions
void dropTriviallyDeadConstantArrays ()
Destroy ConstantArrays in LLVMContext if they are not used.
bool getSemanticInterposition () const
Returns whether semantic interposition is to be respected.
void setSemanticInterposition (bool)
Set whether semantic interposition is to be respected.
bool getRtLibUseGOT () const
Returns true if PLT should be avoided for RTLib calls.
void setRtLibUseGOT ()
Set that PLT should be avoid for RTLib calls.
bool getDirectAccessExternalData () const
Get/set whether referencing global variables can use direct access relocations on ELF targets.
void setDirectAccessExternalData (bool Value)
UWTableKind getUwtable () const
Get/set whether synthesized functions should get the uwtable attribute.
void setUwtable (UWTableKind Kind)
FramePointerKind getFramePointer () const
Get/set whether synthesized functions should get the "frame-pointer" attribute.
void setFramePointer (FramePointerKind Kind)
StringRef getStackProtectorGuard () const
Get/set what kind of stack protector guard to use.
void setStackProtectorGuard (StringRef Kind)
StringRef getStackProtectorGuardReg () const
Get/set which register to use as the stack protector guard register.
void setStackProtectorGuardReg (StringRef Reg)
StringRef getStackProtectorGuardSymbol () const
Get/set a symbol to use as the stack protector guard.
void setStackProtectorGuardSymbol (StringRef Symbol)
int getStackProtectorGuardOffset () const
Get/set what offset from the stack protector to use.
void setStackProtectorGuardOffset (int Offset)
unsigned getOverrideStackAlignment () const
Get/set the stack alignment overridden from the default.
void setOverrideStackAlignment (unsigned Align)
unsigned getMaxTLSAlignment () const
void setOwnedMemoryBuffer (std::unique_ptr< MemoryBuffer > MB)
Take ownership of the given memory buffer.
void setPartialSampleProfileRatio (const ModuleSummaryIndex &Index)
Set the partial sample profile ratio in the profile summary module flag, if applicable.
StringRef getDarwinTargetVariantTriple () const
Get the target variant triple which is a string describing a variant of the target host platform.
void setDarwinTargetVariantTriple (StringRef T)
Set the target variant triple which is a string describing a variant of the target host platform.
VersionTuple getDarwinTargetVariantSDKVersion () const
Get the target variant version build SDK version metadata.
void setDarwinTargetVariantSDKVersion (VersionTuple Version)
Set the target variant version build SDK version metadata.
Module Level Accessors
const std::string & getModuleIdentifier () const
Get the module identifier which is, essentially, the name of the module.
unsigned getInstructionCount () const
Returns the number of non-debug IR instructions in the module.
const std::string & getSourceFileName () const
Get the module's original source file name.
StringRef getName () const
Get a short "name" for the module.
const std::string & getDataLayoutStr () const
Get the data layout string for the module's target platform.
const DataLayout & getDataLayout () const
Get the data layout for the module's target platform.
const std::string & getTargetTriple () const
Get the target triple which is a string describing the target host.
LLVMContext & getContext () const
Get the global data context.
const std::string & getModuleInlineAsm () const
Get any module-scope inline assembly blocks.
std::unique_ptr< RandomNumberGenerator > createRNG (const StringRef Name) const
Get a RandomNumberGenerator salted for use with this module.
bool shouldEmitInstrCountChangedRemark ()
Return true if size-info optimization remark is enabled, false otherwise.
Module Level Mutators
void setModuleIdentifier (StringRef ID)
Set the module identifier.
void setSourceFileName (StringRef Name)
Set the module's original source file name.
void setDataLayout (StringRef Desc)
Set the data layout.
void setDataLayout (const DataLayout &Other)
void setTargetTriple (StringRef T)
Set the target triple.
void setModuleInlineAsm (StringRef Asm)
Set the module-scope inline assembly blocks.
void appendModuleInlineAsm (StringRef Asm)
Append to the module-scope inline assembly blocks.
Generic Value Accessors
GlobalValue * getNamedValue (StringRef Name) const
Return the global value in the module with the specified name, of arbitrary type.
unsigned getNumNamedValues () const
Return the number of global values in the module.
unsigned getMDKindID (StringRef Name) const
Return a unique non-zero ID for the specified metadata kind.
void getMDKindNames (SmallVectorImpl< StringRef > &Result) const
Populate client supplied SmallVector with the name for custom metadata IDs registered in this LLVMContext.
void getOperandBundleTags (SmallVectorImpl< StringRef > &Result) const
Populate client supplied SmallVector with the bundle tags registered in this LLVMContext.
std::vector< StructType * > getIdentifiedStructTypes () const
std::string getUniqueIntrinsicName (StringRef BaseName, Intrinsic::ID Id, const FunctionType *Proto)
Return a unique name for an intrinsic whose mangling is based on an unnamed type.
Function Accessors
FunctionCallee getOrInsertFunction (StringRef Name, FunctionType *T, AttributeList AttributeList)
Look up the specified function in the module symbol table.
FunctionCallee getOrInsertFunction (StringRef Name, FunctionType *T)
template<typename... ArgsTy>
FunctionCallee getOrInsertFunction (StringRef Name, AttributeList AttributeList, Type *RetTy, ArgsTy... Args)
Same as above, but takes a list of function arguments, which makes it easier for clients to use.
template<typename... ArgsTy>
FunctionCallee getOrInsertFunction (StringRef Name, Type *RetTy, ArgsTy... Args)
Same as above, but without the attributes.
template<typename... ArgsTy>
FunctionCallee getOrInsertFunction (StringRef Name, AttributeList AttributeList, FunctionType *Invalid, ArgsTy... Args)=delete
Function * getFunction (StringRef Name) const
Look up the specified function in the module symbol table.
Global Variable Accessors
GlobalVariable * getGlobalVariable (StringRef Name) const
Look up the specified global variable in the module symbol table.
GlobalVariable * getGlobalVariable (StringRef Name, bool AllowInternal) const
getGlobalVariable - Look up the specified global variable in the module symbol table.
GlobalVariable * getGlobalVariable (StringRef Name, bool AllowInternal=false)
const GlobalVariable * getNamedGlobal (StringRef Name) const
Return the global variable in the module with the specified name, of arbitrary type.
GlobalVariable * getNamedGlobal (StringRef Name)
Constant * getOrInsertGlobal (StringRef Name, Type *Ty, function_ref< GlobalVariable *()> CreateGlobalCallback)
Look up the specified global in the module symbol table.
Constant * getOrInsertGlobal (StringRef Name, Type *Ty)
Look up the specified global in the module symbol table.
Global Alias Accessors
GlobalAlias * getNamedAlias (StringRef Name) const
Return the global alias in the module with the specified name, of arbitrary type.
Global IFunc Accessors
GlobalIFunc * getNamedIFunc (StringRef Name) const
Return the global ifunc in the module with the specified name, of arbitrary type.
Named Metadata Accessors
NamedMDNode * getNamedMetadata (StringRef Name) const
Return the first NamedMDNode in the module with the specified name.
NamedMDNode * getOrInsertNamedMetadata (StringRef Name)
Return the named MDNode in the module with the specified name.
void eraseNamedMetadata (NamedMDNode *NMD)
Remove the given NamedMDNode from this module and delete it.
Comdat Accessors
Comdat * getOrInsertComdat (StringRef Name)
Return the Comdat in the module with the specified name.
Module Flags Accessors
void getModuleFlagsMetadata (SmallVectorImpl< ModuleFlagEntry > &Flags) const
Returns the module flags in the provided vector.
Metadata * getModuleFlag (StringRef Key) const
Return the corresponding value if Key appears in module flags, otherwise return null.
NamedMDNode * getModuleFlagsMetadata () const
Returns the NamedMDNode in the module that represents module-level flags.
NamedMDNode * getOrInsertModuleFlagsMetadata ()
Returns the NamedMDNode in the module that represents module-level flags.
void addModuleFlag (ModFlagBehavior Behavior, StringRef Key, Metadata *Val)
Add a module-level flag to the module-level flags metadata.
void addModuleFlag (ModFlagBehavior Behavior, StringRef Key, Constant *Val)
void addModuleFlag (ModFlagBehavior Behavior, StringRef Key, uint32_t Val)
void addModuleFlag (MDNode *Node)
void setModuleFlag (ModFlagBehavior Behavior, StringRef Key, Metadata *Val)
Like addModuleFlag but replaces the old module flag if it already exists.
void setModuleFlag (ModFlagBehavior Behavior, StringRef Key, Constant *Val)
void setModuleFlag (ModFlagBehavior Behavior, StringRef Key, uint32_t Val)
Materialization
void setMaterializer (GVMaterializer *GVM)
Sets the GVMaterializer to GVM.
GVMaterializer * getMaterializer () const
Retrieves the GVMaterializer, if any, for this Module.
bool isMaterialized () const
llvm::Error materialize (GlobalValue *GV)
Make sure the GlobalValue is fully read.
llvm::Error materializeAll ()
Make sure all GlobalValues in this Module are fully read and clear the Materializer.
llvm::Error materializeMetadata ()
void removeGlobalVariable (GlobalVariable *GV)
Detach global variable GV from the list but don't delete it.
void eraseGlobalVariable (GlobalVariable *GV)
Remove global variable GV from the list and delete it.
void insertGlobalVariable (GlobalVariable *GV)
Insert global variable GV at the end of the global variable list and take ownership.
void insertGlobalVariable (GlobalListType::iterator Where, GlobalVariable *GV)
Insert global variable GV into the global variable list before Where and take ownership.
Global Variable Iteration
global_iterator global_begin ()
const_global_iterator global_begin () const
global_iterator global_end ()
const_global_iterator global_end () const
size_t global_size () const
bool global_empty () const
iterator_range< global_iterator > globals ()
iterator_range< const_global_iterator > globals () const
Function Iteration
iterator begin ()
const_iterator begin () const
iterator end ()
const_iterator end () const
reverse_iterator rbegin ()
const_reverse_iterator rbegin () const
reverse_iterator rend ()
const_reverse_iterator rend () const
size_t size () const
bool empty () const
iterator_range< iterator > functions ()
iterator_range< const_iterator > functions () const
Alias Iteration
alias_iterator alias_begin ()
const_alias_iterator alias_begin () const
alias_iterator alias_end ()
const_alias_iterator alias_end () const
size_t alias_size () const
bool alias_empty () const
iterator_range< alias_iterator > aliases ()
iterator_range< const_alias_iterator > aliases () const
IFunc Iteration
ifunc_iterator ifunc_begin ()
const_ifunc_iterator ifunc_begin () const
ifunc_iterator ifunc_end ()
const_ifunc_iterator ifunc_end () const
size_t ifunc_size () const
bool ifunc_empty () const
iterator_range< ifunc_iterator > ifuncs ()
iterator_range< const_ifunc_iterator > ifuncs () const
Named Metadata Iteration
named_metadata_iterator named_metadata_begin ()
const_named_metadata_iterator named_metadata_begin () const
named_metadata_iterator named_metadata_end ()
const_named_metadata_iterator named_metadata_end () const
size_t named_metadata_size () const
bool named_metadata_empty () const
iterator_range< named_metadata_iterator > named_metadata ()
iterator_range< const_named_metadata_iterator > named_metadata () const
debug_compile_units_iterator debug_compile_units_begin () const
debug_compile_units_iterator debug_compile_units_end () const
iterator_range< debug_compile_units_iterator > debug_compile_units () const
Return an iterator for all DICompileUnits listed in this Module's llvm.dbg.cu named metadata node and aren't explicitly marked as NoDebug.
Utility functions for printing and dumping Module objects
void print (raw_ostream &OS, AssemblyAnnotationWriter *AAW, bool ShouldPreserveUseListOrder=false, bool IsForDebug=false) const
Print the module to an output stream with an optional AssemblyAnnotationWriter.
void dump () const
Dump the module to stderr (for debugging).
void dropAllReferences ()
This function causes all the subinstructions to "let go" of all references that they are maintaining.
Utility functions for querying Debug information.
unsigned getNumberRegisterParameters () const
Returns the Number of Register ParametersDwarf Version by checking module flags.
unsigned getDwarfVersion () const
Returns the Dwarf Version by checking module flags.
bool isDwarf64 () const
Returns the DWARF format by checking module flags.
unsigned getCodeViewFlag () const
Returns the CodeView Version by checking module flags.
Utility functions for querying and setting PIC level
PICLevel::Level getPICLevel () const
Returns the PIC level (small or large model)
void setPICLevel (PICLevel::Level PL)
Set the PIC level (small or large model)
Utility functions for querying and setting PIE level
PIELevel::Level getPIELevel () const
Returns the PIE level (small or large model)
void setPIELevel (PIELevel::Level PL)
Set the PIE level (small or large model)
Utility function for querying and setting code model
std::optional< CodeModel::Model > getCodeModel () const
Returns the code model (tiny, small, kernel, medium or large model)
void setCodeModel (CodeModel::Model CL)
Set the code model (tiny, small, kernel, medium or large)
Utility function for querying and setting the large data threshold
std::optional< uint64_t > getLargeDataThreshold () const
Returns the code model (tiny, small, kernel, medium or large model)
void setLargeDataThreshold (uint64_t Threshold)
Set the code model (tiny, small, kernel, medium or large)
Utility functions for querying and setting PGO summary
void setProfileSummary (Metadata *M, ProfileSummary::Kind Kind)
Attach profile summary metadata to this module.
Metadata * getProfileSummary (bool IsCS) const
Returns profile summary metadata.
Utility functions for querying and setting the build SDK version
void setSDKVersion (const VersionTuple &V)
Attach a build SDK version metadata to this module.
VersionTuple getSDKVersion () const
Get the build SDK version metadata.
Types And Enumerations
enum ModFlagBehavior { Error = 1 , Warning = 2 , Require = 3 , Override = 4 , Append = 5 , AppendUnique = 6 , Max = 7 , Min = 8 , ModFlagBehaviorFirstVal = Error , ModFlagBehaviorLastVal = Min }
This enumeration defines the supported behaviors of module flags. More...
using GlobalListType = SymbolTableList< GlobalVariable >
The type for the list of global variables.
using FunctionListType = SymbolTableList< Function >
The type for the list of functions.
using AliasListType = SymbolTableList< GlobalAlias >
The type for the list of aliases.
using IFuncListType = SymbolTableList< GlobalIFunc >
The type for the list of ifuncs.
using NamedMDListType = ilist< NamedMDNode >
The type for the list of named metadata.
using ComdatSymTabType = StringMap< Comdat >
The type of the comdat "symbol" table.
using NamedMDSymTabType = StringMap< NamedMDNode * >
The type for mapping names to named metadata.
using global_iterator = GlobalListType::iterator
The Global Variable iterator.
using const_global_iterator = GlobalListType::const_iterator
The Global Variable constant iterator.
using iterator = FunctionListType::iterator
The Function iterators.
using const_iterator = FunctionListType::const_iterator
The Function constant iterator.
using reverse_iterator = FunctionListType::reverse_iterator
The Function reverse iterator.
using const_reverse_iterator = FunctionListType::const_reverse_iterator
The Function constant reverse iterator.
using alias_iterator = AliasListType::iterator
The Global Alias iterators.
using const_alias_iterator = AliasListType::const_iterator
The Global Alias constant iterator.
using ifunc_iterator = IFuncListType::iterator
The Global IFunc iterators.
using const_ifunc_iterator = IFuncListType::const_iterator
The Global IFunc constant iterator.
using named_metadata_iterator = NamedMDListType::iterator
The named metadata iterators.
using const_named_metadata_iterator = NamedMDListType::const_iterator
The named metadata constant iterators.
static bool isValidModFlagBehavior (Metadata *MD, ModFlagBehavior &MFB)
Checks if Metadata represents a valid ModFlagBehavior, and stores the converted result in MFB.
Convenience iterators
using global_object_iterator = concat_iterator< GlobalObject, iterator, global_iterator >
using const_global_object_iterator = concat_iterator< const GlobalObject, const_iterator, const_global_iterator >
using global_value_iterator = concat_iterator< GlobalValue, iterator, global_iterator, alias_iterator, ifunc_iterator >
using const_global_value_iterator = concat_iterator< const GlobalValue, const_iterator, const_global_iterator, const_alias_iterator, const_ifunc_iterator >
iterator_range< global_object_iterator > global_objects ()
iterator_range< const_global_object_iterator > global_objects () const
iterator_range< global_value_iterator > global_values ()
iterator_range< const_global_value_iterator > global_values () const
Direct access to the globals list, functions list, and symbol table
class llvm::SymbolTableListTraits< llvm::GlobalVariable >
class llvm::SymbolTableListTraits< llvm::GlobalAlias >
class llvm::SymbolTableListTraits< llvm::GlobalIFunc >
static FunctionListType Module::* getSublistAccess (Function *)
const FunctionListType & getFunctionList () const
Get the Module's list of functions (constant).
FunctionListType & getFunctionList ()
Get the Module's list of functions.
void removeAlias (GlobalAlias *Alias)
Detach Alias from the list but don't delete it.
void eraseAlias (GlobalAlias *Alias)
Remove Alias from the list and delete it.
void insertAlias (GlobalAlias *Alias)
Insert Alias at the end of the alias list and take ownership.
void removeIFunc (GlobalIFunc *IFunc)
Detach IFunc from the list but don't delete it.
void eraseIFunc (GlobalIFunc *IFunc)
Remove IFunc from the list and delete it.
void insertIFunc (GlobalIFunc *IFunc)
Insert IFunc at the end of the alias list and take ownership.
void removeNamedMDNode (NamedMDNode *MDNode)
Detach MDNode from the list but don't delete it.
void eraseNamedMDNode (NamedMDNode *MDNode)
Remove MDNode from the list and delete it.
void insertNamedMDNode (NamedMDNode *MDNode)
Insert MDNode at the end of the alias list and take ownership.
const ValueSymbolTable & getValueSymbolTable () const
Get the symbol table of global variable and function identifiers.
ValueSymbolTable & getValueSymbolTable ()
Get the Module's symbol table of global variable and function identifiers.
const ComdatSymTabType & getComdatSymbolTable () const
Get the Module's symbol table for COMDATs (constant).
ComdatSymTabType & getComdatSymbolTable ()
Get the Module's symbol table for COMDATs.
Constructors
bool IsNewDbgInfoFormat
Is this Module using intrinsics to record the position of debugging information, or non-intrinsic records? See IsNewDbgInfoFormat in BasicBlock.
void removeDebugIntrinsicDeclarations ()
Used when printing this module in the new debug info format; removes all declarations of debug intrinsics that are replaced by non-intrinsic records in the new format.
void convertToNewDbgValues ()
void convertFromNewDbgValues ()
void setIsNewDbgInfoFormat (bool UseNewFormat)
void setNewDbgInfoFormatFlag (bool NewFlag)
Module (StringRef ModuleID, LLVMContext &C)
The Module constructor.
~Module ()
The module destructor. This will dropAllReferences.
Module & operator= (Module &&Other)
Move assignment.

A Module instance is used to store all the information related to an LLVM module.

Modules are the top level container of all other LLVM Intermediate Representation (IR) objects. Each module directly contains a list of globals variables, a list of functions, a list of libraries (or other modules) this module depends on, a symbol table, and various data about the target's characteristics.

A module maintains a GlobalList object that is used to hold all constant references to global variables in the module. When a global variable is destroyed, it should have no entries in the GlobalList. The main container class for the LLVM Intermediate Representation.

Definition at line 65 of file Module.h.

alias_iterator

The Global Alias iterators.

Definition at line 100 of file Module.h.

AliasListType

The type for the list of aliases.

Definition at line 74 of file Module.h.

ComdatSymTabType

The type of the comdat "symbol" table.

Definition at line 80 of file Module.h.

const_alias_iterator

The Global Alias constant iterator.

Definition at line 102 of file Module.h.

const_global_iterator

The Global Variable constant iterator.

Definition at line 87 of file Module.h.

const_global_object_iterator

const_global_value_iterator

const_ifunc_iterator

The Global IFunc constant iterator.

Definition at line 107 of file Module.h.

const_iterator

const_named_metadata_iterator

The named metadata constant iterators.

Definition at line 112 of file Module.h.

const_reverse_iterator

FunctionListType

The type for the list of functions.

Definition at line 72 of file Module.h.

global_iterator

The Global Variable iterator.

Definition at line 85 of file Module.h.

global_object_iterator

global_value_iterator

GlobalListType

The type for the list of global variables.

Definition at line 70 of file Module.h.

ifunc_iterator

The Global IFunc iterators.

Definition at line 105 of file Module.h.

IFuncListType

The type for the list of ifuncs.

Definition at line 76 of file Module.h.

iterator

named_metadata_iterator

The named metadata iterators.

Definition at line 110 of file Module.h.

NamedMDListType

The type for the list of named metadata.

Definition at line 78 of file Module.h.

NamedMDSymTabType

The type for mapping names to named metadata.

Definition at line 82 of file Module.h.

reverse_iterator

ModFlagBehavior

This enumeration defines the supported behaviors of module flags.

Enumerator
Error Emits an error if two values disagree, otherwise the resulting value is that of the operands.
Warning Emits a warning if two values disagree. The result value will be the operand for the flag from the first module being linked.
Require Adds a requirement that another module flag be present and have a specified value after linking is performed. The value must be a metadata pair, where the first element of the pair is the ID of the module flag to be restricted, and the second element of the pair is the value the module flag should be restricted to. This behavior can be used to restrict the allowable results (via triggering of an error) of linking IDs with the Override behavior.
Override Uses the specified value, regardless of the behavior or value of the other module. If both modules specify Override, but the values differ, an error will be emitted.
Append Appends the two values, which are required to be metadata nodes.
AppendUnique Appends the two values, which are required to be metadata nodes. However, duplicate entries in the second list are dropped during the append operation.
Max Takes the max of the two values, which are required to be integers.
Min Takes the min of the two values, which are required to be integers.
ModFlagBehaviorFirstVal
ModFlagBehaviorLastVal

Definition at line 115 of file Module.h.

The Module constructor.

Note that there is no default constructor. You must provide a name for the module upon construction.

Definition at line 73 of file Module.cpp.

~Module()

The module destructor. This will dropAllReferences.

Definition at line 115 of file Module.cpp.

addModuleFlag() [1/4]

void Module::addModuleFlag ( MDNode * Node )

addModuleFlag() [2/4]

addModuleFlag() [3/4]

Add a module-level flag to the module-level flags metadata.

addModuleFlag - Add a module-level flag to the module-level flags metadata.

It will create the module-level flags named metadata if it doesn't already exist.

Definition at line 377 of file Module.cpp.

addModuleFlag() [4/4]

alias_begin() [1/2]

alias_begin() [2/2]

alias_empty()

bool llvm::Module::alias_empty ( ) const inline

alias_end() [1/2]

alias_end() [2/2]

alias_size()

size_t llvm::Module::alias_size ( ) const inline

aliases() [1/2]

aliases() [2/2]

appendModuleInlineAsm()

void llvm::Module::appendModuleInlineAsm ( StringRef Asm) inline

Append to the module-scope inline assembly blocks.

A trailing newline is added if the input doesn't have one.

Definition at line 353 of file Module.h.

begin() [1/2]

begin() [2/2]

convertFromNewDbgValues()

void llvm::Module::convertFromNewDbgValues ( ) inline

convertToNewDbgValues()

void llvm::Module::convertToNewDbgValues ( ) inline

createRNG()

Get a RandomNumberGenerator salted for use with this module.

The RNG can be seeded via -rng-seed= and is salted with the ModuleID and the provided pass salt. The returned RNG should not be shared across threads or passes.

A unique RNG per pass ensures a reproducible random stream even when other randomness consuming passes are added or removed. In addition, the random stream will be reproducible across LLVM versions when the pass does not change.

Definition at line 148 of file Module.cpp.

debug_compile_units()

debug_compile_units_begin()

debug_compile_units_end()

dropAllReferences()

void Module::dropAllReferences ( )

This function causes all the subinstructions to "let go" of all references that they are maintaining.

This allows one to 'delete' a whole class at a time, even though there may be circular references... first all references are dropped, and all use counts go to zero. Then everything is delete'd for real. Note that no operations are valid on an object that has "dropped all references", except operator delete.

Definition at line 563 of file Module.cpp.

dropTriviallyDeadConstantArrays()

void Module::dropTriviallyDeadConstantArrays ( )

dump()

void Module::dump ( ) const

empty()

bool llvm::Module::empty ( ) const inline

end() [1/2]

end() [2/2]

eraseAlias()

void llvm::Module::eraseAlias ( GlobalAlias * Alias) inline

eraseGlobalVariable()

eraseIFunc()

void llvm::Module::eraseIFunc ( GlobalIFunc * IFunc) inline

eraseNamedMDNode()

void llvm::Module::eraseNamedMDNode ( NamedMDNode * MDNode) inline

eraseNamedMetadata()

functions() [1/2]

functions() [2/2]

getCodeModel()

getCodeViewFlag()

unsigned Module::getCodeViewFlag ( ) const

getComdatSymbolTable() [1/2]

getComdatSymbolTable() [2/2]

Get the Module's symbol table for COMDATs (constant).

Definition at line 687 of file Module.h.

getContext()

LLVMContext & llvm::Module::getContext ( ) const inline

Get the global data context.

Returns

LLVMContext - a container for LLVM's global information

Definition at line 302 of file Module.h.

Referenced by llvm::AMDGPUMachineModuleInfo::AMDGPUMachineModuleInfo(), llvm::AMDGPUTargetLowering::analyzeFormalArgumentsCompute(), llvm::OpenMPIRBuilder::createAtomicCompare(), llvm::OpenMPIRBuilder::createAtomicRead(), llvm::OpenMPIRBuilder::createAtomicWrite(), llvm::OpenMPIRBuilder::createCopyinClauseBlocks(), llvm::OpenMPIRBuilder::createGlobalFlag(), llvm::OpenMPIRBuilder::createLoopSkeleton(), llvm::OpenMPIRBuilder::createOffloadEntriesAndInfoMetadata(), llvm::OpenMPIRBuilder::createOffloadEntry(), llvm::OpenMPIRBuilder::createOffloadMapnames(), llvm::OpenMPIRBuilder::createOffloadMaptypes(), llvm::OpenMPIRBuilder::createOMPInteropDestroy(), llvm::OpenMPIRBuilder::createOMPInteropInit(), llvm::OpenMPIRBuilder::createOMPInteropUse(), llvm::OpenMPIRBuilder::createParallel(), llvm::OpenMPIRBuilder::createReductions(), llvm::OpenMPIRBuilder::createReductionsGPU(), llvm::OpenMPIRBuilder::createSections(), llvm::OpenMPIRBuilder::createTask(), crossImportIntoModule(), llvm::WebAssemblyAsmPrinter::emitGlobalVariable(), llvm::OpenMPIRBuilder::emitIfClause(), llvm::OpenMPIRBuilder::emitNonContiguousDescriptor(), llvm::OpenMPIRBuilder::emitOffloadingArraysArgument(), llvm::OpenMPIRBuilder::emitTargetTask(), llvm::OpenMPIRBuilder::emitUserDefinedMapper(), llvm::SanitizerStatReport::finish(), llvm::OpenMPIRBuilder::getOrCreateSrcLocStr(), llvm::FunctionImporter::importFunctions(), optimizeModule(), llvm::InlineAdvisorAnalysis::Result::tryCreate(), llvm::dxil::DXILOpBuilder::tryCreateOp(), and verifyLoadedModule().

getDarwinTargetVariantSDKVersion()

VersionTuple Module::getDarwinTargetVariantSDKVersion ( ) const

Get the target variant version build SDK version metadata.

An empty version is returned if no such metadata is attached.

Definition at line 911 of file Module.cpp.

getDarwinTargetVariantTriple()

StringRef Module::getDarwinTargetVariantTriple ( ) const

Get the target variant triple which is a string describing a variant of the target host platform.

For example, Mac Catalyst can be a variant target triple for a macOS target.

Returns

a string containing the target variant triple.

Definition at line 900 of file Module.cpp.

getDataLayout()

Get the data layout for the module's target platform.

Definition at line 294 of file Module.h.

References DL.

Referenced by CanProveNotTakenFirstIteration(), llvm::OpenMPIRBuilder::createAtomicRead(), llvm::OpenMPIRBuilder::createParallel(), llvm::OpenMPIRBuilder::createReductions(), llvm::OpenMPIRBuilder::createReductionsGPU(), llvm::OpenMPIRBuilder::createTask(), llvm::OpenMPIRBuilder::emitNonContiguousDescriptor(), llvm::OpenMPIRBuilder::emitOffloadingArrays(), llvm::OpenMPIRBuilder::emitTargetKernel(), llvm::OpenMPIRBuilder::emitTargetTask(), llvm::OpenMPIRBuilder::emitUserDefinedMapper(), getAuthPtrSlotSymbolHelper(), llvm::AsmPrinter::getDataLayout(), llvm::GlobalValue::getDataLayout(), llvm::sandboxir::Module::getDataLayout(), llvm::TargetLoweringObjectFileMachO::getIndirectSymViaGOTPCRel(), llvm::OpenMPIRBuilder::getOrCreateIdent(), llvm::OpenMPIRBuilder::getOrCreateInternalVariable(), llvm::orc::IRMaterializationUnit::IRMaterializationUnit(), isAtomicRMWLegalXChgTy(), llvm::AArch64TargetLowering::lowerDeinterleaveIntrinsicToLoad(), llvm::OpenMPIRBuilder::registerTargetGlobalVariable(), and valueCoversEntireFragment().

getDataLayoutStr()

const std::string & llvm::Module::getDataLayoutStr ( ) const inline

Get the data layout string for the module's target platform.

This is equivalent to getDataLayout()->getStringRepresentation().

Definition at line 289 of file Module.h.

References DL.

getDirectAccessExternalData()

bool Module::getDirectAccessExternalData ( ) const

Get/set whether referencing global variables can use direct access relocations on ELF targets.

Definition at line 721 of file Module.cpp.

getDwarfVersion()

unsigned Module::getDwarfVersion ( ) const

getFramePointer()

Get/set whether synthesized functions should get the "frame-pointer" attribute.

Definition at line 743 of file Module.cpp.

getFunction()

getFunctionList() [1/2]

getFunctionList() [2/2]

getGlobalVariable() [1/3]

Look up the specified global variable in the module symbol table.

If it does not exist, return null. If AllowInternal is set to true, this function will return types that have InternalLinkage. By default, these types are not returned.

Definition at line 447 of file Module.h.

References getGlobalVariable(), and Name.

Referenced by llvm::OpenMPIRBuilder::finalize().

getGlobalVariable() [2/3]

getGlobalVariable - Look up the specified global variable in the module symbol table.

If it does not exist, return null. The type argument should be the underlying type of the global, i.e., it should not have the top-level PointerType, which represents the address of the global. If AllowLocal is set to true, this function will return types that have an local. By default, these types are not returned.

Definition at line 243 of file Module.cpp.

getGlobalVariable() [3/3]

getIdentifiedStructTypes()

std::vector< StructType * > Module::getIdentifiedStructTypes ( ) const

getInstructionCount()

unsigned Module::getInstructionCount ( ) const

Returns the number of non-debug IR instructions in the module.

This is equivalent to the sum of the IR instruction counts of each function contained in the module.

Definition at line 604 of file Module.cpp.

getLargeDataThreshold()

std::optional< uint64_t > Module::getLargeDataThreshold ( ) const

Returns the code model (tiny, small, kernel, medium or large model)

Definition at line 665 of file Module.cpp.

getMaterializer()

getMaxTLSAlignment()

unsigned Module::getMaxTLSAlignment ( ) const

getMDKindID()

Return a unique non-zero ID for the specified metadata kind.

getMDKindID - Return a unique non-zero ID for the specified metadata kind.

This ID is uniqued across modules in the current LLVMContext.

Definition at line 180 of file Module.cpp.

getMDKindNames()

Populate client supplied SmallVector with the name for custom metadata IDs registered in this LLVMContext.

getMDKindNames - Populate client supplied SmallVector with the name for custom metadata IDs registered in this LLVMContext.

ID #0 is not used, so it is filled in as an empty string.

Definition at line 187 of file Module.cpp.

getModuleFlag()

getModuleFlagsMetadata() [1/2]

NamedMDNode * llvm::Module::getModuleFlagsMetadata ( ) const inline

Returns the NamedMDNode in the module that represents module-level flags.

This method returns null if there are no module-level flags.

Definition at line 537 of file Module.h.

getModuleFlagsMetadata() [2/2]

Returns the module flags in the provided vector.

getModuleFlagsMetadata - Returns the module flags in the provided vector.

Definition at line 337 of file Module.cpp.

getModuleIdentifier()

const std::string & llvm::Module::getModuleIdentifier ( ) const inline

Get the module identifier which is, essentially, the name of the module.

Returns

the module identifier as a string

Definition at line 268 of file Module.h.

Referenced by llvm::ThinLTOCodeGenerator::crossModuleImport(), llvm::ThinLTOCodeGenerator::emitImports(), llvm::ThinLTOCodeGenerator::gatherImportedSummariesForModule(), llvm::DOTGraphTraits< CallGraphDOTInfo * >::getGraphName(), llvm::Loop::getLocStr(), llvm::FunctionImporter::importFunctions(), llvm::ThinLTOCodeGenerator::internalize(), llvm::DiagnosticInfoIgnoringInvalidDebugMetadata::print(), llvm::PassManagerPrettyStackEntry::print(), llvm::ThinLTOCodeGenerator::promote(), and llvm::cgdata::saveModuleForTwoRounds().

getModuleInlineAsm()

const std::string & llvm::Module::getModuleInlineAsm ( ) const inline

Get any module-scope inline assembly blocks.

Returns

a string containing the module-scope inline assembly blocks.

Definition at line 306 of file Module.h.

getName()

StringRef llvm::Module::getName ( ) const inline

getNamedAlias()

Return the global alias in the module with the specified name, of arbitrary type.

This method returns null if a global with the specified name is not found.

Definition at line 286 of file Module.cpp.

getNamedGlobal() [1/2]

getNamedGlobal() [2/2]

getNamedIFunc()

Return the global ifunc in the module with the specified name, of arbitrary type.

This method returns null if a global with the specified name is not found.

Definition at line 290 of file Module.cpp.

getNamedMetadata()

getNamedValue()

getNumberRegisterParameters()

unsigned Module::getNumberRegisterParameters ( ) const

Returns the Number of Register ParametersDwarf Version by checking module flags.

Definition at line 577 of file Module.cpp.

getNumNamedValues()

unsigned Module::getNumNamedValues ( ) const

Return the number of global values in the module.

Definition at line 174 of file Module.cpp.

getOperandBundleTags()

getOrInsertComdat()

Return the Comdat in the module with the specified name.

It is created if it didn't already exist.

Definition at line 611 of file Module.cpp.

getOrInsertFunction() [1/5]

template<typename... ArgsTy>

getOrInsertFunction() [2/5]

template<typename... ArgsTy>

Same as above, but takes a list of function arguments, which makes it easier for clients to use.

Definition at line 413 of file Module.h.

References Name, and RetTy.

getOrInsertFunction() [3/5]

getOrInsertFunction() [4/5]

getOrInsertFunction() [5/5]

template<typename... ArgsTy>

Same as above, but without the attributes.

Definition at line 424 of file Module.h.

References Name, and RetTy.

getOrInsertGlobal() [1/2]

Look up the specified global in the module symbol table.

If required, this overload constructs the global variable using its constructor's defaults.

Definition at line 272 of file Module.cpp.

getOrInsertGlobal() [2/2]

Look up the specified global in the module symbol table.

getOrInsertGlobal - Look up the specified global in the module symbol table.

If it does not exist, invoke a callback to create a declaration of the global and return it. The global is constantexpr casted to the expected type if necessary.

  1. If it does not exist, add a declaration of the global and return it.
  2. Else, the global exists but has the wrong type: return the function with a constantexpr cast to the right type.
  3. Finally, if the existing global is the correct declaration, return the existing global.

Definition at line 258 of file Module.cpp.

getOrInsertModuleFlagsMetadata()

NamedMDNode * Module::getOrInsertModuleFlagsMetadata ( )

Returns the NamedMDNode in the module that represents module-level flags.

getOrInsertModuleFlagsMetadata - Returns the NamedMDNode in the module that represents module-level flags.

If module-level flags aren't found, it creates the named metadata that contains them.

Definition at line 368 of file Module.cpp.

getOrInsertNamedMetadata()

getOverrideStackAlignment()

unsigned Module::getOverrideStackAlignment ( ) const

Get/set the stack alignment overridden from the default.

Definition at line 800 of file Module.cpp.

getPICLevel()

Returns the PIC level (small or large model)

Definition at line 617 of file Module.cpp.

getPIELevel()

getProfileSummary()

getRtLibUseGOT()

bool Module::getRtLibUseGOT ( ) const

Returns true if PLT should be avoided for RTLib calls.

Definition at line 712 of file Module.cpp.

getSDKVersion()

Get the build SDK version metadata.

An empty version is returned if no such metadata is attached.

Definition at line 861 of file Module.cpp.

getSemanticInterposition()

bool Module::getSemanticInterposition ( ) const

getSourceFileName()

const std::string & llvm::Module::getSourceFileName ( ) const inline

getStackProtectorGuard()

StringRef Module::getStackProtectorGuard ( ) const

Get/set what kind of stack protector guard to use.

Definition at line 753 of file Module.cpp.

getStackProtectorGuardOffset()

int Module::getStackProtectorGuardOffset ( ) const

Get/set what offset from the stack protector to use.

Definition at line 789 of file Module.cpp.

getStackProtectorGuardReg()

StringRef Module::getStackProtectorGuardReg ( ) const

Get/set which register to use as the stack protector guard register.

The empty string is equivalent to "global". Other values may be "tls" or "sysreg".

Definition at line 765 of file Module.cpp.

getStackProtectorGuardSymbol()

StringRef Module::getStackProtectorGuardSymbol ( ) const

Get/set a symbol to use as the stack protector guard.

Definition at line 777 of file Module.cpp.

getSublistAccess()

getTargetTriple()

const std::string & llvm::Module::getTargetTriple ( ) const inline

Get the target triple which is a string describing the target host.

Returns

a string containing the target triple.

Definition at line 298 of file Module.h.

Referenced by llvm::ModuleSymbolTable::addModule(), llvm::CodeViewDebug::beginFunctionImpl(), llvm::GlobalObject::canIncreaseAlignment(), llvm::ThinLTOCodeGenerator::crossModuleImport(), llvm::ThinLTOCodeGenerator::emitImports(), llvm::CodeViewDebug::endFunctionImpl(), llvm::ThinLTOCodeGenerator::gatherImportedSummariesForModule(), llvm::OpenMPIRBuilder::getOrCreateInternalVariable(), llvm::LTOModule::getTargetTriple(), insertSinCosCall(), llvm::ThinLTOCodeGenerator::internalize(), llvm::TargetLibraryInfoImpl::isCallingConvCCompatible(), llvm::ThinLTOCodeGenerator::optimize(), and llvm::ThinLTOCodeGenerator::promote().

getUniqueIntrinsicName()

Return a unique name for an intrinsic whose mangling is based on an unnamed type.

The Proto represents the function prototype.

Definition at line 506 of file Module.cpp.

getUwtable()

Get/set whether synthesized functions should get the uwtable attribute.

Definition at line 733 of file Module.cpp.

getValueSymbolTable() [1/2]

Get the Module's symbol table of global variable and function identifiers.

Definition at line 684 of file Module.h.

getValueSymbolTable() [2/2]

Get the symbol table of global variable and function identifiers.

Definition at line 682 of file Module.h.

global_begin() [1/2]

global_begin() [2/2]

global_empty()

bool llvm::Module::global_empty ( ) const inline

global_end() [1/2]

global_end() [2/2]

global_objects() [1/2]

global_objects() [2/2]

global_size()

size_t llvm::Module::global_size ( ) const inline

global_values() [1/2]

global_values() [2/2]

globals() [1/2]

globals() [2/2]

ifunc_begin() [1/2]

ifunc_begin() [2/2]

ifunc_empty()

bool llvm::Module::ifunc_empty ( ) const inline

ifunc_end() [1/2]

ifunc_end() [2/2]

ifunc_size()

size_t llvm::Module::ifunc_size ( ) const inline

ifuncs() [1/2]

ifuncs() [2/2]

insertAlias()

void llvm::Module::insertAlias ( GlobalAlias * Alias) inline

Insert Alias at the end of the alias list and take ownership.

Definition at line 626 of file Module.h.

insertGlobalVariable() [1/2]

Insert global variable GV into the global variable list before Where and take ownership.

Definition at line 591 of file Module.h.

insertGlobalVariable() [2/2]

insertIFunc()

void llvm::Module::insertIFunc ( GlobalIFunc * IFunc) inline

Insert IFunc at the end of the alias list and take ownership.

Definition at line 635 of file Module.h.

insertNamedMDNode()

void llvm::Module::insertNamedMDNode ( NamedMDNode * MDNode) inline

Insert [MDNode](classllvm%5F1%5F1MDNode.html "Metadata node.") at the end of the alias list and take ownership.

Definition at line 644 of file Module.h.

isDwarf64()

bool Module::isDwarf64 ( ) const

isMaterialized()

bool llvm::Module::isMaterialized ( ) const inline

isValidModFlagBehavior()

Checks if Metadata represents a valid ModFlagBehavior, and stores the converted result in MFB.

Definition at line 325 of file Module.cpp.

materialize()

materializeAll()

Error Module::materializeAll ( )

Make sure all GlobalValues in this Module are fully read and clear the Materializer.

Definition at line 475 of file Module.cpp.

materializeMetadata()

Error Module::materializeMetadata ( )

named_metadata() [1/2]

named_metadata() [2/2]

named_metadata_begin() [1/2]

named_metadata_begin() [2/2]

named_metadata_empty()

bool llvm::Module::named_metadata_empty ( ) const inline

named_metadata_end() [1/2]

named_metadata_end() [2/2]

named_metadata_size()

size_t llvm::Module::named_metadata_size ( ) const inline

operator=()

print()

Print the module to an output stream with an optional AssemblyAnnotationWriter.

If ShouldPreserveUseListOrder, then include uselistorder directives so that use-lists can be recreated when reading the assembly.

Definition at line 4912 of file AsmWriter.cpp.

References OS.

Referenced by dump().

rbegin() [1/2]

rbegin() [2/2]

removeAlias()

void llvm::Module::removeAlias ( GlobalAlias * Alias) inline

removeDebugIntrinsicDeclarations()

void Module::removeDebugIntrinsicDeclarations ( )

Used when printing this module in the new debug info format; removes all declarations of debug intrinsics that are replaced by non-intrinsic records in the new format.

Definition at line 124 of file Module.cpp.

removeGlobalVariable()

removeIFunc()

void llvm::Module::removeIFunc ( GlobalIFunc * IFunc) inline

removeNamedMDNode()

void llvm::Module::removeNamedMDNode ( NamedMDNode * MDNode) inline

Detach [MDNode](classllvm%5F1%5F1MDNode.html "Metadata node.") from the list but don't delete it.

Definition at line 640 of file Module.h.

rend() [1/2]

rend() [2/2]

setCodeModel()

Set the code model (tiny, small, kernel, medium or large)

Definition at line 657 of file Module.cpp.

setDarwinTargetVariantSDKVersion()

void Module::setDarwinTargetVariantSDKVersion ( VersionTuple Version )

Set the target variant version build SDK version metadata.

Definition at line 915 of file Module.cpp.

setDarwinTargetVariantTriple()

void Module::setDarwinTargetVariantTriple ( StringRef T )

Set the target variant triple which is a string describing a variant of the target host platform.

Definition at line 906 of file Module.cpp.

setDataLayout() [1/2]

setDataLayout() [2/2]

setDirectAccessExternalData()

void Module::setDirectAccessExternalData ( bool Value )

setFramePointer()

setIsNewDbgInfoFormat()

void llvm::Module::setIsNewDbgInfoFormat ( bool UseNewFormat) inline

setLargeDataThreshold()

void Module::setLargeDataThreshold ( uint64_t Threshold )

Set the code model (tiny, small, kernel, medium or large)

Definition at line 675 of file Module.cpp.

setMaterializer()

Sets the GVMaterializer to GVM.

This module must not yet have a Materializer. To reset the materializer for a module that already has one, call materializeAll first. Destroying this module will destroy its materializer without materializing any more GlobalValues. Without destroying the Module, there is no way to detach or destroy a materializer without materializing all the GVs it controls, to avoid leaving orphan unmaterialized GVs.

Definition at line 461 of file Module.cpp.

setModuleFlag() [1/3]

setModuleFlag() [2/3]

Like addModuleFlag but replaces the old module flag if it already exists.

Definition at line 403 of file Module.cpp.

setModuleFlag() [3/3]

setModuleIdentifier()

void llvm::Module::setModuleIdentifier ( StringRef ID) inline

Set the module identifier.

Definition at line 331 of file Module.h.

setModuleInlineAsm()

void llvm::Module::setModuleInlineAsm ( StringRef Asm) inline

Set the module-scope inline assembly blocks.

A trailing newline is added if the input doesn't have one.

Definition at line 345 of file Module.h.

setNewDbgInfoFormatFlag()

void llvm::Module::setNewDbgInfoFormatFlag ( bool NewFlag) inline

setOverrideStackAlignment()

void Module::setOverrideStackAlignment ( unsigned Align )

setOwnedMemoryBuffer()

void Module::setOwnedMemoryBuffer ( std::unique_ptr< MemoryBuffer > MB )

Take ownership of the given memory buffer.

Definition at line 708 of file Module.cpp.

setPartialSampleProfileRatio()

Set the partial sample profile ratio in the profile summary module flag, if applicable.

Definition at line 880 of file Module.cpp.

setPICLevel()

Set the PIC level (small or large model)

Definition at line 627 of file Module.cpp.

setPIELevel()

Set the PIE level (small or large model)

Definition at line 643 of file Module.cpp.

setProfileSummary()

Attach profile summary metadata to this module.

Definition at line 682 of file Module.cpp.

setRtLibUseGOT()

void Module::setRtLibUseGOT ( )

Set that PLT should be avoid for RTLib calls.

Definition at line 717 of file Module.cpp.

setSDKVersion()

Attach a build SDK version metadata to this module.

Definition at line 832 of file Module.cpp.

setSemanticInterposition()

void Module::setSemanticInterposition ( bool SI )

Set whether semantic interposition is to be respected.

Definition at line 704 of file Module.cpp.

setSourceFileName()

void llvm::Module::setSourceFileName ( StringRef Name) inline

Set the module's original source file name.

Definition at line 334 of file Module.h.

References Name.

setStackProtectorGuard()

void Module::setStackProtectorGuard ( StringRef Kind )

setStackProtectorGuardOffset()

void Module::setStackProtectorGuardOffset ( int Offset )

setStackProtectorGuardReg()

void Module::setStackProtectorGuardReg ( StringRef Reg )

setStackProtectorGuardSymbol()

void Module::setStackProtectorGuardSymbol ( StringRef Symbol )

setTargetTriple()

void llvm::Module::setTargetTriple ( StringRef T) inline

setUwtable()

shouldEmitInstrCountChangedRemark()

bool llvm::Module::shouldEmitInstrCountChangedRemark ( ) inline

Return true if size-info optimization remark is enabled, false otherwise.

Definition at line 321 of file Module.h.

size()

size_t llvm::Module::size ( ) const inline

Constant

llvm::SymbolTableListTraits< llvm::GlobalAlias >

llvm::SymbolTableListTraits< llvm::GlobalIFunc >

llvm::SymbolTableListTraits< llvm::GlobalVariable >

IsNewDbgInfoFormat

bool llvm::Module::IsNewDbgInfoFormat


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