66 cl::desc(
"Maximum size for the name of non-global values."));
69 validateBlockNumbers();
72 for (
auto &BB : *
this)
73 BB.Number = NextBlockNum++;
77void Function::validateBlockNumbers()
const {
80 for (
const auto &BB : *
this) {
81 unsigned Num = BB.getNumber();
82 assert(Num < NextBlockNum &&
"out of range block number");
83 assert(!Numbers[Num] &&
"duplicate block numbers");
90 for (
auto &BB : *
this) {
91 BB.convertToNewDbgValues();
96 for (
auto &BB : *
this) {
97 BB.convertFromNewDbgValues();
106 : Value(Ty, Value::ArgumentVal), Parent(Par), ArgNo(ArgNo) {
110void Argument::setParent(
Function *parent) {
117 if (
Attrs.hasAttribute(Attribute::NonNull) &&
118 (AllowUndefOrPoison ||
Attrs.hasAttribute(Attribute::NoUndef)))
120 else if (getDereferenceableBytes() > 0 &&
129 return hasAttribute(Attribute::ByVal);
134 return getParent()->getDeadOnReturnInfo(getArgNo());
140 return hasAttribute(Attribute::ByRef);
144 return getParent()->hasParamAttribute(getArgNo(), Attribute::SwiftSelf);
148 return getParent()->hasParamAttribute(getArgNo(), Attribute::SwiftError);
153 return hasAttribute(Attribute::InAlloca);
159 return hasAttribute(Attribute::Preallocated);
165 return Attrs.hasAttribute(Attribute::ByVal) ||
166 Attrs.hasAttribute(Attribute::InAlloca) ||
167 Attrs.hasAttribute(Attribute::Preallocated);
174 return Attrs.hasAttribute(Attribute::ByVal) ||
175 Attrs.hasAttribute(Attribute::StructRet) ||
176 Attrs.hasAttribute(Attribute::InAlloca) ||
177 Attrs.hasAttribute(Attribute::Preallocated) ||
178 Attrs.hasAttribute(Attribute::ByRef);
202 return DL.getTypeAllocSize(MemTy);
212 return getParent()->getParamAlign(getArgNo());
216 return getParent()->getParamStackAlign(getArgNo());
221 return getParent()->getParamByValType(getArgNo());
226 return getParent()->getParamStructRetType(getArgNo());
231 return getParent()->getParamByRefType(getArgNo());
236 return getParent()->getParamInAllocaType(getArgNo());
241 "Only pointers have dereferenceable bytes");
242 return getParent()->getParamDereferenceableBytes(getArgNo());
247 "Only pointers have dereferenceable bytes");
248 return getParent()->getParamDereferenceableOrNullBytes(getArgNo());
252 return getParent()->getParamNoFPClass(getArgNo());
256 const Attribute RangeAttr = getAttribute(llvm::Attribute::Range);
257 if (RangeAttr.isValid())
258 return RangeAttr.getRange();
264 return hasAttribute(Attribute::Nest);
269 return hasAttribute(Attribute::NoAlias);
279 return hasAttribute(Attribute::NoFree);
284 return hasAttribute(Attribute::StructRet);
288 return hasAttribute(Attribute::InReg);
292 return hasAttribute(Attribute::Returned);
296 return hasAttribute(Attribute::ZExt);
300 return hasAttribute(Attribute::SExt);
305 return Attrs.hasAttribute(Attribute::ReadOnly) ||
306 Attrs.hasAttribute(Attribute::ReadNone);
311 AL =
AL.addParamAttributes(Parent->getContext(), getArgNo(),
B);
316 getParent()->addParamAttr(getArgNo(), Kind);
320 getParent()->addParamAttr(getArgNo(), Attr);
324 getParent()->removeParamAttr(getArgNo(), Kind);
329 AL =
AL.removeParamAttributes(Parent->getContext(), getArgNo(), AM);
334 return getParent()->hasParamAttribute(getArgNo(), Kind);
338 return getParent()->hasParamAttribute(getArgNo(), Kind);
342 return getParent()->getParamAttribute(getArgNo(), Kind);
346 return getParent()->getAttributes().getParamAttrs(getArgNo());
354 return getType()->getContext();
362 unsigned NumInstrs = 0;
364 NumInstrs += BB.size();
370 return Create(Ty,
Linkage, M.getDataLayout().getProgramAddressSpace(),
N, &M);
375 unsigned AddrSpace,
const Twine &
N,
378 AttrBuilder
B(
F->getContext());
381 B.addUWTableAttr(UWTable);
382 switch (M->getFramePointer()) {
387 B.addAttribute(
"frame-pointer",
"reserved");
390 B.addAttribute(
"frame-pointer",
"non-leaf");
393 B.addAttribute(
"frame-pointer",
"non-leaf-no-reserve");
396 B.addAttribute(
"frame-pointer",
"all");
399 if (M->getModuleFlag(
"function_return_thunk_extern"))
400 B.addAttribute(Attribute::FnRetThunkExtern);
401 StringRef DefaultCPU =
F->getContext().getDefaultTargetCPU();
402 if (!DefaultCPU.
empty())
403 B.addAttribute(
"target-cpu", DefaultCPU);
404 StringRef DefaultFeatures =
F->getContext().getDefaultTargetFeatures();
405 if (!DefaultFeatures.
empty())
406 B.addAttribute(
"target-features", DefaultFeatures);
409 auto isModuleAttributeSet = [&](
const StringRef &ModAttr) ->
bool {
412 return Attr && !Attr->isZero();
415 auto AddAttributeIfSet = [&](
const StringRef &ModAttr) {
416 if (isModuleAttributeSet(ModAttr))
417 B.addAttribute(ModAttr);
421 if (isModuleAttributeSet(
"sign-return-address"))
422 SignType =
"non-leaf";
423 if (isModuleAttributeSet(
"sign-return-address-all"))
425 if (SignType !=
"none") {
426 B.addAttribute(
"sign-return-address", SignType);
427 B.addAttribute(
"sign-return-address-key",
428 isModuleAttributeSet(
"sign-return-address-with-bkey")
432 AddAttributeIfSet(
"branch-target-enforcement");
433 AddAttributeIfSet(
"branch-protection-pauth-lr");
434 AddAttributeIfSet(
"guarded-control-stack");
441 getParent()->getFunctionList().remove(getIterator());
445 getParent()->getFunctionList().erase(getIterator());
451#ifdef EXPENSIVE_CHECKS
453 auto FromFEnd = FromF->
end();
454 for (
auto It = FromBeginIt; It != FromEndIt; ++It)
455 assert(It != FromFEnd &&
"FromBeginIt not before FromEndIt!");
457 BasicBlocks.splice(ToIt, FromF->BasicBlocks, FromBeginIt, FromEndIt);
462 return BasicBlocks.erase(FromIt, ToIt);
472 if (AddrSpace ==
static_cast<unsigned>(-1))
473 return M ? M->getDataLayout().getProgramAddressSpace() : 0;
481 NumArgs(Ty->getNumParams()) {
483 "invalid return type");
484 setGlobalObjectSubClassData(0);
491 if (Ty->getNumParams())
492 setValueSubclassData(1);
498 HasLLVMReservedName =
getName().starts_with(
"llvm.");
514 validateBlockNumbers();
526void Function::BuildLazyArguments()
const {
528 auto *FT = getFunctionType();
530 Arguments = std::allocator<Argument>().allocate(NumArgs);
531 for (
unsigned i = 0, e = NumArgs; i !=
e; ++i) {
532 Type *ArgTy = FT->getParamType(i);
533 assert(!ArgTy->isVoidTy() &&
"Cannot have void typed arguments!");
539 unsigned SDC = getSubclassDataFromValue();
541 const_cast<Function*
>(
this)->setValueSubclassData(SDC);
542 assert(!hasLazyArguments());
553void Function::clearArguments() {
558 std::allocator<Argument>().deallocate(
Arguments, NumArgs);
563 assert(isDeclaration() &&
"Expected no references to current arguments");
566 if (!hasLazyArguments()) {
568 [](
const Argument &
A) {
return A.use_empty(); }) &&
569 "Expected arguments to be unused in declaration");
571 setValueSubclassData(getSubclassDataFromValue() | (1 << 0));
575 if (Src.hasLazyArguments())
579 assert(arg_size() == Src.arg_size());
581 Src.Arguments =
nullptr;
594 setValueSubclassData(getSubclassDataFromValue() & ~(1 << 0));
595 assert(!hasLazyArguments());
596 Src.setValueSubclassData(Src.getSubclassDataFromValue() | (1 << 0));
599void Function::deleteBodyImpl(
bool ShouldDrop) {
600 setIsMaterializable(
false);
607 while (!BasicBlocks.empty())
608 BasicBlocks.begin()->eraseFromParent();
610 if (getNumOperands()) {
614 setNumHungOffUseOperands(0);
622 setValueSubclassData(getSubclassDataFromValue() & ~0xe);
630 AttributeSets = AttributeSets.addAttributeAtIndex(
getContext(), i, Attr);
634 AttributeSets = AttributeSets.addFnAttribute(
getContext(), Kind);
638 AttributeSets = AttributeSets.addFnAttribute(
getContext(), Kind, Val);
642 AttributeSets = AttributeSets.addFnAttribute(
getContext(), Attr);
646 AttributeSets = AttributeSets.addFnAttributes(
getContext(), Attrs);
650 AttributeSets = AttributeSets.addRetAttribute(
getContext(), Kind);
654 AttributeSets = AttributeSets.addRetAttribute(
getContext(), Attr);
658 AttributeSets = AttributeSets.addRetAttributes(
getContext(), Attrs);
662 AttributeSets = AttributeSets.addParamAttribute(
getContext(), ArgNo, Kind);
666 AttributeSets = AttributeSets.addParamAttribute(
getContext(), ArgNo, Attr);
670 AttributeSets = AttributeSets.addParamAttributes(
getContext(), ArgNo, Attrs);
674 AttributeSets = AttributeSets.removeAttributeAtIndex(
getContext(), i, Kind);
678 AttributeSets = AttributeSets.removeAttributeAtIndex(
getContext(), i, Kind);
682 AttributeSets = AttributeSets.removeFnAttribute(
getContext(), Kind);
686 AttributeSets = AttributeSets.removeFnAttribute(
getContext(), Kind);
690 AttributeSets = AttributeSets.removeFnAttributes(
getContext(), AM);
694 AttributeSets = AttributeSets.removeRetAttribute(
getContext(), Kind);
698 AttributeSets = AttributeSets.removeRetAttribute(
getContext(), Kind);
702 AttributeSets = AttributeSets.removeRetAttributes(
getContext(), Attrs);
706 AttributeSets = AttributeSets.removeParamAttribute(
getContext(), ArgNo, Kind);
710 AttributeSets = AttributeSets.removeParamAttribute(
getContext(), ArgNo, Kind);
715 AttributeSets.removeParamAttributes(
getContext(), ArgNo, Attrs);
720 AttributeSets.addDereferenceableParamAttr(
getContext(), ArgNo, Bytes);
724 return AttributeSets.hasFnAttr(Kind);
728 return AttributeSets.hasFnAttr(Kind);
732 return AttributeSets.hasRetAttr(Kind);
737 return AttributeSets.hasParamAttr(ArgNo, Kind);
741 return AttributeSets.hasParamAttr(ArgNo, Kind);
746 return AttributeSets.getAttributeAtIndex(i, Kind);
750 return AttributeSets.getAttributeAtIndex(i, Kind);
755 return AttributeSets.hasAttributeAtIndex(Idx, Kind);
759 return AttributeSets.getFnAttr(Kind);
763 return AttributeSets.getFnAttr(Kind);
767 return AttributeSets.getRetAttr(Kind);
772 Attribute
A = getFnAttribute(Name);
774 if (
A.isStringAttribute()) {
776 if (Str.getAsInteger(0, Result))
777 getContext().emitError(
"cannot parse integer attribute " + Name);
786 return AttributeSets.getParamAttr(ArgNo, Kind);
791 AttributeSets = AttributeSets.addDereferenceableOrNullParamAttr(
getContext(),
796 AttributeSets = AttributeSets.addRangeRetAttr(
getContext(), CR);
800 Attribute Attr = getFnAttribute(Attribute::DenormalFPEnv);
809 Attribute Attr = getFnAttribute(Attribute::DenormalFPEnv);
814 assert(hasGC() &&
"Function has no collector");
819 setValueSubclassDataBit(14, !Str.empty());
827 setValueSubclassDataBit(14,
false);
831 return hasFnAttribute(Attribute::StackProtect) ||
832 hasFnAttribute(Attribute::StackProtectStrong) ||
833 hasFnAttribute(Attribute::StackProtectReq);
840 setCallingConv(Src->getCallingConv());
841 setAttributes(Src->getAttributes());
846 if (Src->hasPersonalityFn())
847 setPersonalityFn(Src->getPersonalityFn());
848 if (Src->hasPrefixData())
849 setPrefixData(Src->getPrefixData());
850 if (Src->hasPrologueData())
851 setPrologueData(Src->getPrologueData());
863 return getMemoryEffects().doesNotAccessMemory();
871 return getMemoryEffects().onlyReadsMemory();
879 return getMemoryEffects().onlyWritesMemory();
888 return getMemoryEffects().onlyAccessesArgPointees();
897 return getMemoryEffects().onlyAccessesInaccessibleMem();
906 return getMemoryEffects().onlyAccessesInaccessibleOrArgMem();
918 LibFuncCache = UnknownLibFunc;
920 if (!
Name.starts_with(
"llvm.")) {
921 HasLLVMReservedName =
false;
925 HasLLVMReservedName =
true;
934 bool IgnoreCallbackUses,
935 bool IgnoreAssumeLikeCalls,
bool IgnoreLLVMUsed,
936 bool IgnoreARCAttachedCall,
937 bool IgnoreCastedDirectCall)
const {
938 for (
const Use &U : uses()) {
939 const User *FU = U.getUser();
940 if (IgnoreCallbackUses) {
942 if (ACS && ACS.isCallbackCall())
948 if (IgnoreAssumeLikeCalls &&
951 if (const auto *I = dyn_cast<IntrinsicInst>(U))
952 return I->isAssumeLikeIntrinsic();
959 const User *FUU = FU;
964 if (const auto *GV = dyn_cast<GlobalVariable>(U))
965 return GV->hasName() &&
966 (GV->getName() ==
"llvm.compiler.used" ||
967 GV->getName() ==
"llvm.used");
977 if (IgnoreAssumeLikeCalls) {
979 if (
I->isAssumeLikeIntrinsic())
983 if (!
Call->isCallee(&U) || (!IgnoreCastedDirectCall &&
984 Call->getFunctionType() != getFunctionType())) {
985 if (IgnoreARCAttachedCall &&
1000 if (!hasLinkOnceLinkage() && !hasLocalLinkage() &&
1001 !hasAvailableExternallyLinkage())
1012 if (
Call->hasFnAttr(Attribute::ReturnsTwice))
1019 assert(hasPersonalityFn() && getNumOperands());
1024 setHungoffOperand<0>(Fn);
1025 setValueSubclassDataBit(3, Fn !=
nullptr);
1029 assert(hasPrefixData() && getNumOperands());
1034 setHungoffOperand<1>(PrefixData);
1035 setValueSubclassDataBit(1, PrefixData !=
nullptr);
1039 assert(hasPrologueData() && getNumOperands());
1044 setHungoffOperand<2>(PrologueData);
1045 setValueSubclassDataBit(2, PrologueData !=
nullptr);
1048void Function::allocHungoffUselist() {
1050 if (getNumOperands())
1053 allocHungoffUses(3,
false);
1054 setNumHungOffUseOperands(3);
1064void Function::setHungoffOperand(Constant *
C) {
1066 allocHungoffUselist();
1068 }
else if (getNumOperands()) {
1073void Function::setValueSubclassDataBit(
unsigned Bit,
bool On) {
1074 assert(Bit < 16 &&
"SubclassData contains only 16 bits");
1076 setValueSubclassData(getSubclassDataFromValue() | (1 << Bit));
1078 setValueSubclassData(getSubclassDataFromValue() & ~(1 << Bit));
1083 auto ImportGUIDs = getImportGUIDs();
1084 if (S ==
nullptr && ImportGUIDs.size())
1088 setMetadata(LLVMContext::MD_prof,
1089 MDB.createFunctionEntryCount(
Count,
false, S));
1093 MDNode *MD = getMetadata(LLVMContext::MD_prof);
1097 return std::nullopt;
1103 return std::nullopt;
1106 return std::nullopt;
1111 if (
MDNode *MD = getMetadata(LLVMContext::MD_prof))
1122 return hasFnAttribute(Attribute::NullPointerIsValid);
1126 Attribute Attr = getFnAttribute(Attribute::VScaleRange);
1127 if (!Attr.isValid())
1130 unsigned VScale = Attr.getVScaleRangeMin();
1131 if (VScale && VScale == Attr.getVScaleRangeMax())
1138 if (
F &&
F->nullPointerIsDefined())
static unsigned getIntrinsicID(const SDNode *N)
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
AMDGPU Lower Kernel Arguments
MachineBasicBlock MachineBasicBlock::iterator DebugLoc DL
Expand Atomic instructions
This file contains the simple types necessary to represent the attributes associated with functions a...
static const Function * getParent(const Value *V)
This file implements the BitVector class.
static bool setMemoryEffects(Function &F, MemoryEffects ME)
static GCRegistry::Add< ShadowStackGC > C("shadow-stack", "Very portable GC for uncooperative code generators")
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define LLVM_EXPORT_TEMPLATE
This file contains the declarations for the subclasses of Constant, which represent the different fla...
This file defines the DenseSet and SmallDenseSet classes.
Module.h This file contains the declarations for the Module class.
This defines the Use class.
Machine Check Debug Module
This file contains the declarations for profiling metadata utility functions.
static StringRef getName(Value *V)
static Type * getMemoryParamAllocType(AttributeSet ParamAttrs)
For a byval, sret, inalloca, or preallocated parameter, get the in-memory parameter type.
static cl::opt< int > NonGlobalValueMaxNameSize("non-global-value-max-name-size", cl::Hidden, cl::init(1024), cl::desc("Maximum size for the name of non-global values."))
static MutableArrayRef< Argument > makeArgArray(Argument *Args, size_t Count)
static unsigned computeAddrSpace(unsigned AddrSpace, Module *M)
This file defines the SmallString class.
This file defines the SmallVector class.
static SymbolRef::Type getType(const Symbol *Sym)
static const fltSemantics & IEEEsingle()
uint64_t getZExtValue() const
Get zero extended value.
This class represents an incoming formal argument to a Function.
LLVM_ABI Type * getParamByRefType() const
If this is a byref argument, return its type.
LLVM_ABI DeadOnReturnInfo getDeadOnReturnInfo() const
Returns information on the memory marked dead_on_return for the argument.
LLVM_ABI Attribute getAttribute(Attribute::AttrKind Kind) const
LLVM_ABI bool hasNoAliasAttr() const
Return true if this argument has the noalias attribute.
LLVM_ABI bool hasNonNullAttr(bool AllowUndefOrPoison=true) const
Return true if this argument has the nonnull attribute.
LLVM_ABI bool hasByRefAttr() const
Return true if this argument has the byref attribute.
LLVM_ABI uint64_t getDereferenceableOrNullBytes() const
If this argument has the dereferenceable_or_null attribute, return the number of bytes known to be de...
LLVM_ABI void addAttr(Attribute::AttrKind Kind)
LLVM_ABI Argument(Type *Ty, const Twine &Name="", Function *F=nullptr, unsigned ArgNo=0)
Argument constructor.
LLVM_ABI bool onlyReadsMemory() const
Return true if this argument has the readonly or readnone attribute.
LLVM_ABI bool hasPointeeInMemoryValueAttr() const
Return true if this argument has the byval, sret, inalloca, preallocated, or byref attribute.
LLVM_ABI bool hasAttribute(Attribute::AttrKind Kind) const
Check if an argument has a given attribute.
LLVM_ABI bool hasReturnedAttr() const
Return true if this argument has the returned attribute.
LLVM_ABI Type * getParamStructRetType() const
If this is an sret argument, return its type.
LLVM_ABI bool hasInRegAttr() const
Return true if this argument has the inreg attribute.
LLVM_ABI bool hasByValAttr() const
Return true if this argument has the byval attribute.
LLVM_ABI bool hasPreallocatedAttr() const
Return true if this argument has the preallocated attribute.
LLVM_ABI bool hasSExtAttr() const
Return true if this argument has the sext attribute.
LLVM_ABI void removeAttr(Attribute::AttrKind Kind)
Remove attributes from an argument.
LLVM_ABI uint64_t getPassPointeeByValueCopySize(const DataLayout &DL) const
If this argument satisfies has hasPassPointeeByValueAttr, return the in-memory ABI size copied to the...
LLVM_ABI void removeAttrs(const AttributeMask &AM)
LLVM_ABI Type * getPointeeInMemoryValueType() const
If hasPointeeInMemoryValueAttr returns true, the in-memory ABI type is returned.
LLVM_ABI bool hasInAllocaAttr() const
Return true if this argument has the inalloca attribute.
LLVM_ABI bool hasSwiftErrorAttr() const
Return true if this argument has the swifterror attribute.
LLVM_ABI FPClassTest getNoFPClass() const
If this argument has nofpclass attribute, return the mask representing disallowed floating-point valu...
LLVM_ABI void addAttrs(AttrBuilder &B)
Add attributes to an argument.
LLVM_ABI bool hasNoFreeAttr() const
Return true if this argument has the nofree attribute.
LLVM_ABI bool hasSwiftSelfAttr() const
Return true if this argument has the swiftself attribute.
LLVM_ABI Type * getParamInAllocaType() const
If this is an inalloca argument, return its type.
LLVM_ABI bool hasZExtAttr() const
Return true if this argument has the zext attribute.
LLVM_ABI Type * getParamByValType() const
If this is a byval argument, return its type.
LLVM_ABI bool hasNestAttr() const
Return true if this argument has the nest attribute.
LLVM_ABI MaybeAlign getParamAlign() const
If this is a byval or inalloca argument, return its alignment.
LLVM_ABI std::optional< ConstantRange > getRange() const
If this argument has a range attribute, return the value range of the argument.
LLVM_ABI bool hasStructRetAttr() const
Return true if this argument has the sret attribute.
LLVM_ABI AttributeSet getAttributes() const
LLVM_ABI bool hasPassPointeeByValueCopyAttr() const
Return true if this argument has the byval, inalloca, or preallocated attribute.
LLVM_ABI MaybeAlign getParamStackAlign() const
LLVM_ABI bool hasNoCaptureAttr() const
Return true if this argument has the nocapture attribute.
LLVM_ABI uint64_t getDereferenceableBytes() const
If this argument has the dereferenceable attribute, return the number of bytes known to be dereferenc...
This class stores enough information to efficiently remove some attributes from an existing AttrBuild...
This class holds the attributes for a particular argument, parameter, function, or return value.
LLVM_ABI Type * getInAllocaType() const
LLVM_ABI Type * getByValType() const
LLVM_ABI Type * getStructRetType() const
LLVM_ABI Type * getPreallocatedType() const
LLVM_ABI Type * getByRefType() const
AttrKind
This enumeration lists the attributes that can be associated with parameters, function results,...
static LLVM_ABI Attribute getWithMemoryEffects(LLVMContext &Context, MemoryEffects ME)
LLVM Basic Block Representation.
LLVM_ABI void dropAllReferences()
Cause all subinstructions to "let go" of all the references that said subinstructions are maintaining...
This is the shared class of boolean and integer constants.
const APInt & getValue() const
Return the constant as an APInt value reference.
static LLVM_ABI ConstantPointerNull * get(PointerType *T)
Static factory methods - Return objects of the specified value.
This class represents a range of values.
A parsed version of the target data layout string in and methods for querying it.
Implements a dense probed hash-table based set.
static LLVM_ABI bool isValidReturnType(Type *RetTy)
Return true if the specified type is valid as a return type.
void addFnAttr(Attribute::AttrKind Kind)
Add function attributes to this function.
unsigned getVScaleValue() const
Return the value for vscale based on the vscale_range attribute or 0 when unknown.
static Function * Create(FunctionType *Ty, LinkageTypes Linkage, unsigned AddrSpace, const Twine &N="", Module *M=nullptr)
void addParamAttrs(unsigned ArgNo, const AttrBuilder &Attrs)
adds the attributes to the list of attributes for the given arg.
void removeRetAttr(Attribute::AttrKind Kind)
removes the attribute from the return value list of attributes.
void addRetAttrs(const AttrBuilder &Attrs)
Add return value attributes to this function.
bool isDefTriviallyDead() const
isDefTriviallyDead - Return true if it is trivially safe to remove this function definition from the ...
bool onlyAccessesInaccessibleMemOrArgMem() const
Determine if the function may only access memory that is either inaccessible from the IR or pointed t...
void splice(Function::iterator ToIt, Function *FromF)
Transfer all blocks from FromF to this function at ToIt.
BasicBlockListType::iterator iterator
bool hasAddressTaken(const User **=nullptr, bool IgnoreCallbackUses=false, bool IgnoreAssumeLikeCalls=true, bool IngoreLLVMUsed=false, bool IgnoreARCAttachedCall=false, bool IgnoreCastedDirectCall=false) const
hasAddressTaken - returns true if there are any uses of this function other than direct calls or invo...
void removeParamAttr(unsigned ArgNo, Attribute::AttrKind Kind)
removes the attribute from the list of attributes.
bool nullPointerIsDefined() const
Check if null pointer dereferencing is considered undefined behavior for the function.
Attribute getParamAttribute(unsigned ArgNo, Attribute::AttrKind Kind) const
gets the specified attribute from the list of attributes.
void setPrefixData(Constant *PrefixData)
bool hasStackProtectorFnAttr() const
Returns true if the function has ssp, sspstrong, or sspreq fn attrs.
void removeFromParent()
removeFromParent - This method unlinks 'this' from the containing module, but does not delete it.
const DataLayout & getDataLayout() const
Get the data layout of the module this function belongs to.
void addFnAttrs(const AttrBuilder &Attrs)
Add function attributes to this function.
void renumberBlocks()
Renumber basic blocks into a dense value range starting from 0.
void setDoesNotAccessMemory()
void setGC(std::string Str)
Attribute getFnAttribute(Attribute::AttrKind Kind) const
Return the attribute for the given attribute kind.
uint64_t getFnAttributeAsParsedInteger(StringRef Kind, uint64_t Default=0) const
For a string attribute Kind, parse attribute as an integer.
bool isConstrainedFPIntrinsic() const
Returns true if the function is one of the "Constrained Floating-PointIntrinsics".
void setOnlyAccessesArgMemory()
MemoryEffects getMemoryEffects() const
void setOnlyAccessesInaccessibleMemory()
void removeParamAttrs(unsigned ArgNo, const AttributeMask &Attrs)
removes the attribute from the list of attributes.
bool hasParamAttribute(unsigned ArgNo, Attribute::AttrKind Kind) const
check if an attributes is in the list of attributes.
bool hasAttributeAtIndex(unsigned Idx, Attribute::AttrKind Kind) const
Check if attribute of the given kind is set at the given index.
static Function * createWithDefaultAttr(FunctionType *Ty, LinkageTypes Linkage, unsigned AddrSpace, const Twine &N="", Module *M=nullptr)
Creates a function with some attributes recorded in llvm.module.flags and the LLVMContext applied.
void setOnlyReadsMemory()
bool isTargetIntrinsic() const
isTargetIntrinsic - Returns true if this function is an intrinsic and the intrinsic is specific to a ...
void removeFnAttrs(const AttributeMask &Attrs)
void addRetAttr(Attribute::AttrKind Kind)
Add return value attributes to this function.
DenormalFPEnv getDenormalFPEnv() const
Return the representational value of the denormal_fpenv attribute.
Constant * getPrologueData() const
Get the prologue data associated with this function.
void convertFromNewDbgValues()
Constant * getPersonalityFn() const
Get the personality function associated with this function.
void setOnlyWritesMemory()
void setPersonalityFn(Constant *Fn)
DenseSet< GlobalValue::GUID > getImportGUIDs() const
Returns the set of GUIDs that needs to be imported to the function for sample PGO,...
void removeAttributeAtIndex(unsigned i, Attribute::AttrKind Kind)
removes the attribute from the list of attributes.
void eraseFromParent()
eraseFromParent - This method unlinks 'this' from the containing module and deletes it.
void removeFnAttr(Attribute::AttrKind Kind)
Remove function attributes from this function.
void addDereferenceableOrNullParamAttr(unsigned ArgNo, uint64_t Bytes)
adds the dereferenceable_or_null attribute to the list of attributes for the given arg.
void addRangeRetAttr(const ConstantRange &CR)
adds the range attribute to the list of attributes for the return value.
void stealArgumentListFrom(Function &Src)
Steal arguments from another function.
std::optional< uint64_t > getEntryCount() const
Get the entry count for this function.
LLVMContext & getContext() const
getContext - Return a reference to the LLVMContext associated with this function.
const std::string & getGC() const
void addParamAttr(unsigned ArgNo, Attribute::AttrKind Kind)
adds the attribute to the list of attributes for the given arg.
bool doesNotAccessMemory() const
Determine if the function does not access memory.
DenormalMode getDenormalMode(const fltSemantics &FPType) const
Returns the denormal handling type for the default rounding mode of the function.
void updateAfterNameChange()
Update internal caches that depend on the function name (such as the intrinsic ID and libcall cache).
void setEntryCount(uint64_t Count, const DenseSet< GlobalValue::GUID > *Imports=nullptr)
Set the entry count for this function.
bool callsFunctionThatReturnsTwice() const
callsFunctionThatReturnsTwice - Return true if the function has a call to setjmp or other function th...
bool hasRetAttribute(Attribute::AttrKind Kind) const
check if an attribute is in the list of attributes for the return value.
bool onlyWritesMemory() const
Determine if the function does not access or only writes memory.
bool onlyAccessesInaccessibleMemory() const
Determine if the function may only access memory that is inaccessible from the IR.
void setPrologueData(Constant *PrologueData)
void removeRetAttrs(const AttributeMask &Attrs)
removes the attributes from the return value list of attributes.
bool onlyAccessesArgMemory() const
Determine if the call can access memory only using pointers based on its arguments.
Function::iterator erase(Function::iterator FromIt, Function::iterator ToIt)
Erases a range of BasicBlocks from FromIt to (not including) ToIt.
void setMemoryEffects(MemoryEffects ME)
Constant * getPrefixData() const
Get the prefix data associated with this function.
Attribute getAttributeAtIndex(unsigned i, Attribute::AttrKind Kind) const
gets the attribute from the list of attributes.
void convertToNewDbgValues()
void setOnlyAccessesInaccessibleMemOrArgMem()
void addDereferenceableParamAttr(unsigned ArgNo, uint64_t Bytes)
adds the dereferenceable attribute to the list of attributes for the given arg.
unsigned getInstructionCount() const
Returns the number of non-debug IR instructions in this function.
bool onlyReadsMemory() const
Determine if the function does not access or only reads memory.
void addAttributeAtIndex(unsigned i, Attribute Attr)
adds the attribute to the list of attributes.
bool hasFnAttribute(Attribute::AttrKind Kind) const
Return true if the function has the attribute.
void copyAttributesFrom(const Function *Src)
copyAttributesFrom - copy all additional attributes (those not needed to create a Function) from the ...
Attribute getRetAttribute(Attribute::AttrKind Kind) const
Return the attribute for the given attribute kind for the return value.
LLVM_ABI void copyAttributesFrom(const GlobalObject *Src)
This is an important class for using LLVM in a threaded context.
@ OB_clang_arc_attachedcall
const MDOperand & getOperand(unsigned I) const
unsigned getNumOperands() const
Return number of MDNode operands.
static MemoryEffectsBase readOnly()
static MemoryEffectsBase argMemOnly(ModRefInfo MR=ModRefInfo::ModRef)
static MemoryEffectsBase inaccessibleMemOnly(ModRefInfo MR=ModRefInfo::ModRef)
static MemoryEffectsBase writeOnly()
static MemoryEffectsBase inaccessibleOrArgMemOnly(ModRefInfo MR=ModRefInfo::ModRef)
static MemoryEffectsBase none()
const FunctionListType & getFunctionList() const
Get the Module's list of functions (constant).
Represent a mutable reference to an array (0 or more elements consecutively in memory),...
static LLVM_ABI PointerType * get(Type *ElementType, unsigned AddressSpace)
This constructs a pointer to an object of the specified type in a numbered address space.
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Represent a constant reference to a string, i.e.
constexpr bool empty() const
Check if the string is empty.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
A Use represents the edge between a Value definition and its users.
void dropAllReferences()
Drop all references to operands.
user_iterator user_begin()
bool hasOneUse() const
Return true if there is exactly one use of this value.
iterator_range< user_iterator > users()
void push_back(pointer val)
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr char Attrs[]
Key for Kernel::Metadata::mAttrs.
LLVM_ABI LLVM_READNONE bool supportsNonVoidReturnType(CallingConv::ID CC)
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ ARM64EC_Thunk_Native
Calling convention used in the ARM64EC ABI to implement calls between ARM64 code and thunks.
@ AArch64_VectorCall
Used between AArch64 Advanced SIMD functions.
@ X86_64_SysV
The C convention as specified in the x86-64 supplement to the System V ABI, used on most non-Windows ...
@ RISCV_VectorCall
Calling convention used for RISC-V V-extension.
@ AMDGPU_CS
Used for Mesa/AMDPAL compute shaders.
@ M68k_INTR
Used for M68k interrupt routines.
@ AMDGPU_VS
Used for Mesa vertex shaders, or AMDPAL last shader stage before rasterization (vertex shader if tess...
@ MSP430_BUILTIN
Used for special MSP430 rtlib functions which have an "optimized" convention using additional registe...
@ AVR_SIGNAL
Used for AVR signal routines.
@ HiPE
Used by the High-Performance Erlang Compiler (HiPE).
@ Swift
Calling convention for Swift.
@ AMDGPU_KERNEL
Used for AMDGPU code object kernels.
@ AArch64_SVE_VectorCall
Used between AArch64 SVE functions.
@ ARM_APCS
ARM Procedure Calling Standard (obsolete, but still used on some targets).
@ CFGuard_Check
Special calling convention on Windows for calling the Control Guard Check ICall funtion.
@ AVR_INTR
Used for AVR interrupt routines.
@ PreserveMost
Used for runtime calls that preserves most registers.
@ AnyReg
OBSOLETED - Used for stack based JavaScript calls.
@ AMDGPU_Gfx
Used for AMD graphics targets.
@ DUMMY_HHVM
Placeholders for HHVM calling conventions (deprecated, removed).
@ AMDGPU_CS_ChainPreserve
Used on AMDGPUs to give the middle-end more control over argument placement.
@ AMDGPU_HS
Used for Mesa/AMDPAL hull shaders (= tessellation control shaders).
@ ARM_AAPCS
ARM Architecture Procedure Calling Standard calling convention (aka EABI).
@ AMDGPU_GS
Used for Mesa/AMDPAL geometry shaders.
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X2
Preserve X2-X15, X19-X29, SP, Z0-Z31, P0-P15.
@ CXX_FAST_TLS
Used for access functions.
@ X86_INTR
x86 hardware interrupt context.
@ RISCV_VLSCall_32
Calling convention used for RISC-V V-extension fixed vectors.
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X0
Preserve X0-X13, X19-X29, SP, Z0-Z31, P0-P15.
@ WASM_EmscriptenInvoke
For emscripten __invoke_* functions.
@ AMDGPU_CS_Chain
Used on AMDGPUs to give the middle-end more control over argument placement.
@ AVR_BUILTIN
Used for special AVR rtlib functions which have an "optimized" convention to preserve registers.
@ GHC
Used by the Glasgow Haskell Compiler (GHC).
@ AMDGPU_PS
Used for Mesa/AMDPAL pixel shaders.
@ Cold
Attempts to make code in the caller as efficient as possible under the assumption that the call is no...
@ AArch64_SME_ABI_Support_Routines_PreserveMost_From_X1
Preserve X1-X15, X19-X29, SP, Z0-Z31, P0-P15.
@ X86_ThisCall
Similar to X86_StdCall.
@ PTX_Device
Call to a PTX device function.
@ SPIR_KERNEL
Used for SPIR kernel functions.
@ PreserveAll
Used for runtime calls that preserves (almost) all registers.
@ X86_StdCall
stdcall is mostly used by the Win32 API.
@ SPIR_FUNC
Used for SPIR non-kernel device functions.
@ Fast
Attempts to make calls as fast as possible (e.g.
@ MSP430_INTR
Used for MSP430 interrupt routines.
@ X86_VectorCall
MSVC calling convention that passes vectors and vector aggregates in SSE registers.
@ Intel_OCL_BI
Used for Intel OpenCL built-ins.
@ PreserveNone
Used for runtime calls that preserves none general registers.
@ AMDGPU_ES
Used for AMDPAL shader stage before geometry shader if geometry is in use.
@ Tail
Attemps to make calls as fast as possible while guaranteeing that tail call optimization can always b...
@ Win64
The C convention as implemented on Windows/x86-64 and AArch64.
@ SwiftTail
This follows the Swift calling convention in how arguments are passed but guarantees tail calls will ...
@ GRAAL
Used by GraalVM. Two additional registers are reserved.
@ AMDGPU_LS
Used for AMDPAL vertex shader if tessellation is in use.
@ ARM_AAPCS_VFP
Same as ARM_AAPCS, but uses hard floating point ABI.
@ ARM64EC_Thunk_X64
Calling convention used in the ARM64EC ABI to implement calls between x64 code and thunks.
@ M68k_RTD
Used for M68k rtd-based CC (similar to X86's stdcall).
@ C
The default llvm calling convention, compatible with C.
@ X86_FastCall
'fast' analog of X86_StdCall.
LLVM_ABI bool isConstrainedFPIntrinsic(ID QID)
Returns true if the intrinsic ID is for one of the "ConstrainedFloating-Point Intrinsics".
LLVM_ABI ID lookupIntrinsicID(StringRef Name)
This does the actual lookup of an intrinsic ID which matches the given function name.
LLVM_ABI AttributeList getAttributes(LLVMContext &C, ID id, FunctionType *FT)
Return the attributes for an intrinsic.
LLVM_ABI bool isSignatureValid(Intrinsic::ID ID, FunctionType *FT, SmallVectorImpl< Type * > &OverloadTys, raw_ostream &OS=nulls())
Returns true if FT is a valid function type for intrinsic ID.
LLVM_ABI bool isTargetIntrinsic(ID IID)
isTargetIntrinsic - Returns true if IID is an intrinsic specific to a certain target.
initializer< Ty > init(const Ty &Val)
std::enable_if_t< detail::IsValidPointer< X, Y >::value, X * > extract_or_null(Y &&MD)
Extract a Value from Metadata, allowing null.
std::enable_if_t< detail::IsValidPointer< X, Y >::value, X * > extract(Y &&MD)
Extract a Value from Metadata.
Context & getContext() const
This is an optimization pass for GlobalISel generic memory operations.
bool all_of(R &&range, UnaryPredicate P)
Provide wrappers to std::all_of which take ranges instead of having to pass begin/end explicitly.
unsigned getPointerAddressSpace(const Type *T)
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
MemoryEffectsBase< IRMemLocation > MemoryEffects
Summary of how a function affects memory in the program.
@ None
No unwind table requested.
LLVM_ABI bool NullPointerIsDefined(const Function *F, unsigned AS=0)
Check whether null pointer dereferencing is considered undefined behavior for a given function or an ...
bool isPointerTy(const Type *T)
FunctionAddr VTableAddr Count
bool isa(const From &Val)
isa<X> - Return true if the parameter to the template is an instance of one of the template type argu...
DWARFExpression::Operation Op
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
bool capturesNothing(CaptureComponents CC)
Represents the full denormal controls for a function, including the default mode and the f32 specific...
static constexpr DenormalFPEnv getDefault()
Represent subnormal handling kind for floating point instruction inputs and outputs.
static constexpr DenormalMode getDefault()
Return the assumed default mode for a function without denormal-fp-math.
static LLVM_ABI const char * FunctionEntryCount
This struct is a compact representation of a valid (power of two) or undefined (0) alignment.