41 "Disable metadata propagation fixes discovered through Issue #147390"));
46 : InsertAt(InsertBefore ? InsertBefore->getIterator()
47 : InstListType::iterator()) {}
49 : InsertAt(InsertAtEnd ? InsertAtEnd->
end() : InstListType::iterator()) {}
55 if (InstListType::iterator InsertIt = InsertBefore; InsertIt.isValid()) {
57 assert(BB &&
"Instruction to insert before is not in a basic block!");
58 insertInto(BB, InsertBefore);
74 if (isUsedByMetadata())
81 updateDIAssignIDMapping(
nullptr);
95 return getModule()->getDataLayout();
100 handleMarkerRemoval();
102 getParent()->getInstList().remove(getIterator());
109 DebugMarker->removeMarker();
113 handleMarkerRemoval();
114 return getParent()->getInstList().erase(getIterator());
124 insertBefore(*InsertPos->getParent(), InsertPos);
138 DestParent->getInstList().
insertAfter(InsertPos,
this);
144 assert((It == ParentBB->
end() || It->getParent() == ParentBB) &&
145 "It not in ParentBB");
146 insertBefore(*ParentBB, It);
147 return getIterator();
151 InstListType::iterator InsertPos) {
154 BB.getInstList().
insert(InsertPos,
this);
159 bool InsertAtHead = InsertPos.getHeadBit();
162 if (SrcMarker && !SrcMarker->
empty()) {
175 adoptDbgRecords(&BB, InsertPos,
false);
183 getParent()->flushTerminatorDbgRecords();
193 moveBeforeImpl(*MovePos->getParent(), MovePos,
false);
201 moveBeforeImpl(*MovePos->getParent(), MovePos,
true);
208 NextIt.setHeadBit(
true);
209 moveBeforeImpl(*MovePos->
getParent(), NextIt,
false);
215 MovePos.setHeadBit(
true);
216 moveBeforeImpl(*MovePos->getParent(), MovePos,
false);
223 NextIt.setHeadBit(
true);
224 moveBeforeImpl(*MovePos->
getParent(), NextIt,
true);
228 moveBeforeImpl(BB,
I,
false);
232 InstListType::iterator
I) {
233 moveBeforeImpl(BB,
I,
true);
236void Instruction::moveBeforeImpl(
BasicBlock &BB, InstListType::iterator
I,
239 bool InsertAtHead =
I.getHeadBit();
243 if (DebugMarker && !Preserve) {
244 if (
I != this->getIterator() || InsertAtHead) {
247 handleMarkerRemoval();
260 if (!InsertAtHead && NextMarker && !NextMarker->
empty()) {
261 adoptDbgRecords(&BB,
I,
false);
266 getParent()->flushTerminatorDbgRecords();
270 const Instruction *From, std::optional<DbgRecord::self_iterator> FromHere,
278 return DebugMarker->cloneDebugInfoFrom(From->
DebugMarker, FromHere,
282std::optional<DbgRecord::self_iterator>
301 auto ReleaseTrailingDbgRecords = [BB, It, SrcMarker]() {
302 if (BB->
end() == It) {
309 ReleaseTrailingDbgRecords();
316 if (DebugMarker || It == BB->
end()) {
319 DebugMarker->absorbDebugValues(*SrcMarker, InsertAtHead);
330 ReleaseTrailingDbgRecords();
335 DebugMarker = SrcMarker;
343 DebugMarker->dropDbgRecords();
347 DebugMarker->dropOneDbgRecord(DVR);
352 "instructions without BB parents have no order");
354 "cross-BB instruction order comparison");
357 return Order <
Other->Order;
361 assert(!
getType()->isVoidTy() &&
"Instruction must define result");
368 InsertBB =
II->getNormalDest();
375 assert(!isTerminator() &&
"Only invoke/callbr terminators return value");
377 InsertPt = std::next(getIterator());
381 InsertPt.setHeadBit(
true);
386 if (InsertPt == InsertBB->
end())
392 return any_of(operands(), [](
const Value *V) {
return V->hasOneUser(); });
397 Inst->setHasNoUnsignedWrap(b);
404 Inst->setHasNoSignedWrap(b);
421 return Inst->hasNoUnsignedWrap();
428 return Inst->hasNoSignedWrap();
443 switch (getOpcode()) {
444 case Instruction::Add:
445 case Instruction::Sub:
446 case Instruction::Mul:
447 case Instruction::Shl:
452 case Instruction::UDiv:
453 case Instruction::SDiv:
454 case Instruction::AShr:
455 case Instruction::LShr:
459 case Instruction::Or:
463 case Instruction::GetElementPtr:
467 case Instruction::UIToFP:
468 case Instruction::ZExt:
472 case Instruction::Trunc:
477 case Instruction::ICmp:
481 case Instruction::Call: {
483 switch (
II->getIntrinsicID()) {
484 case Intrinsic::ctlz:
485 case Intrinsic::cttz:
500 assert(!hasPoisonGeneratingFlags() &&
"must be kept in sync");
505 [
this](
unsigned ID) {
return hasMetadata(
ID); });
511 if (!hasMetadata(LLVMContext::MD_loop))
515 MDNode *LoopMD = getMetadata(LLVMContext::MD_loop);
539 return Attrs.hasAttribute(Attribute::Range) ||
540 Attrs.hasAttribute(Attribute::Alignment) ||
541 Attrs.hasAttribute(Attribute::NonNull) ||
542 Attrs.hasAttribute(Attribute::NoFPClass);
544 if (HasPoisonGeneratingAttributes(CB->getRetAttributes()))
546 for (
unsigned ArgNo = 0; ArgNo < CB->arg_size(); ArgNo++)
547 if (HasPoisonGeneratingAttributes(CB->getParamAttributes(ArgNo)))
560 CB->removeRetAttrs(AM);
561 for (
unsigned ArgNo = 0; ArgNo < CB->arg_size(); ArgNo++)
562 CB->removeParamAttrs(ArgNo, AM);
564 assert(!hasPoisonGeneratingAttributes() &&
"must be kept in sync");
569 dropUnknownNonDebugMetadata(KnownIDs);
576 AttributeList
AL = CB->getAttributes();
580 AttributeFuncs::getUBImplyingAttributes();
581 for (
unsigned ArgNo = 0; ArgNo < CB->arg_size(); ArgNo++)
582 CB->removeParamAttrs(ArgNo, UBImplyingAttributes);
583 CB->removeRetAttrs(UBImplyingAttributes);
592 static const unsigned KnownIDs[] = {
593 LLVMContext::MD_annotation, LLVMContext::MD_range,
594 LLVMContext::MD_nonnull, LLVMContext::MD_align,
595 LLVMContext::MD_fpmath, LLVMContext::MD_prof};
597 KeepIDs.
reserve(
Keep.size() + std::size(KnownIDs));
601 dropUBImplyingAttrsAndUnknownMetadata(KeepIDs);
610 for (
unsigned ArgNo = 0; ArgNo < CB->arg_size(); ArgNo++)
611 if (CB->isPassingUndefUB(ArgNo))
613 return CB->hasRetAttr(Attribute::NoUndef) ||
614 CB->hasRetAttr(Attribute::Dereferenceable) ||
615 CB->hasRetAttr(Attribute::DereferenceableOrNull);
718 copyFastMathFlags(
I->getFastMathFlags());
725 setHasNoSignedWrap(
OB->hasNoSignedWrap());
726 setHasNoUnsignedWrap(
OB->hasNoUnsignedWrap());
732 setHasNoSignedWrap(TI->hasNoSignedWrap());
733 setHasNoUnsignedWrap(TI->hasNoUnsignedWrap());
740 setIsExact(PE->isExact());
744 DestPD->setIsDisjoint(SrcPD->isDisjoint());
749 copyFastMathFlags(
FP->getFastMathFlags());
753 DestGEP->setNoWrapFlags(SrcGEP->getNoWrapFlags() |
754 DestGEP->getNoWrapFlags());
758 setNonNeg(NNI->hasNonNeg());
762 DestICmp->setSameSign(SrcICmp->hasSameSign());
782 setIsExact(isExact() && PE->isExact());
786 DestPD->setIsDisjoint(DestPD->isDisjoint() && SrcPD->isDisjoint());
791 FM &=
FP->getFastMathFlags();
792 copyFastMathFlags(FM);
798 DestGEP->setNoWrapFlags(SrcGEP->getNoWrapFlags() &
799 DestGEP->getNoWrapFlags());
803 setNonNeg(hasNonNeg() && NNI->hasNonNeg());
807 DestICmp->setSameSign(DestICmp->hasSameSign() && SrcICmp->hasSameSign());
813 case Ret:
return "ret";
814 case UncondBr:
return "br";
815 case CondBr:
return "br";
816 case Switch:
return "switch";
817 case IndirectBr:
return "indirectbr";
818 case Invoke:
return "invoke";
819 case Resume:
return "resume";
820 case Unreachable:
return "unreachable";
821 case CleanupRet:
return "cleanupret";
822 case CatchRet:
return "catchret";
823 case CatchPad:
return "catchpad";
824 case CatchSwitch:
return "catchswitch";
825 case CallBr:
return "callbr";
828 case FNeg:
return "fneg";
831 case Add:
return "add";
832 case FAdd:
return "fadd";
833 case Sub:
return "sub";
834 case FSub:
return "fsub";
835 case Mul:
return "mul";
836 case FMul:
return "fmul";
837 case UDiv:
return "udiv";
838 case SDiv:
return "sdiv";
839 case FDiv:
return "fdiv";
840 case URem:
return "urem";
841 case SRem:
return "srem";
842 case FRem:
return "frem";
845 case And:
return "and";
846 case Or :
return "or";
847 case Xor:
return "xor";
850 case Alloca:
return "alloca";
851 case Load:
return "load";
852 case Store:
return "store";
853 case AtomicCmpXchg:
return "cmpxchg";
854 case AtomicRMW:
return "atomicrmw";
855 case Fence:
return "fence";
856 case GetElementPtr:
return "getelementptr";
859 case Trunc:
return "trunc";
860 case ZExt:
return "zext";
861 case SExt:
return "sext";
862 case FPTrunc:
return "fptrunc";
863 case FPExt:
return "fpext";
864 case FPToUI:
return "fptoui";
865 case FPToSI:
return "fptosi";
866 case UIToFP:
return "uitofp";
867 case SIToFP:
return "sitofp";
868 case IntToPtr:
return "inttoptr";
869 case PtrToAddr:
return "ptrtoaddr";
870 case PtrToInt:
return "ptrtoint";
871 case BitCast:
return "bitcast";
872 case AddrSpaceCast:
return "addrspacecast";
875 case ICmp:
return "icmp";
876 case FCmp:
return "fcmp";
877 case PHI:
return "phi";
878 case Select:
return "select";
879 case Call:
return "call";
880 case Shl:
return "shl";
881 case LShr:
return "lshr";
882 case AShr:
return "ashr";
883 case VAArg:
return "va_arg";
884 case ExtractElement:
return "extractelement";
885 case InsertElement:
return "insertelement";
886 case ShuffleVector:
return "shufflevector";
887 case ExtractValue:
return "extractvalue";
888 case InsertValue:
return "insertvalue";
889 case LandingPad:
return "landingpad";
890 case CleanupPad:
return "cleanuppad";
891 case Freeze:
return "freeze";
893 default:
return "<Invalid operator> ";
900 bool IgnoreAlignment,
901 bool IntersectAttrs)
const {
902 const auto *
I1 =
this;
904 "Can not compare special state of different instructions");
906 auto CheckAttrsSame = [IntersectAttrs](
const CallBase *CB0,
908 return IntersectAttrs
910 .intersectWith(CB0->
getContext(), CB1->getAttributes())
916 return AI->getAllocatedType() ==
cast<AllocaInst>(I2)->getAllocatedType() &&
932 return CI->getPredicate() ==
cast<CmpInst>(I2)->getPredicate();
948 if (Case1.getCaseValue() != Case2.getCaseValue())
964 CXI->getSuccessOrdering() ==
966 CXI->getFailureOrdering() ==
968 CXI->getSyncScopeID() ==
979 return SVI->getShuffleMask() ==
982 return GEP->getSourceElementType() ==
989 return isIdenticalToWhenDefined(
I) &&
990 SubclassOptionalData ==
I->SubclassOptionalData;
994 bool IntersectAttrs)
const {
995 if (getOpcode() !=
I->getOpcode() ||
996 getNumOperands() !=
I->getNumOperands() ||
getType() !=
I->getType())
1000 if (getNumOperands() == 0 &&
I->getNumOperands() == 0)
1001 return this->hasSameSpecialState(
I,
false,
1006 if (!
equal(operands(),
I->operands()))
1015 return this->hasSameSpecialState(
I,
false,
1022 unsigned flags)
const {
1023 bool IgnoreAlignment = flags & CompareIgnoringAlignment;
1024 bool UseScalarTypes = flags & CompareUsingScalarTypes;
1025 bool IntersectAttrs = flags & CompareUsingIntersectedAttrs;
1027 if (getOpcode() !=
I->getOpcode() ||
1028 getNumOperands() !=
I->getNumOperands() ||
1030 getType()->getScalarType() !=
I->getType()->getScalarType() :
1036 for (
unsigned i = 0, e = getNumOperands(); i !=
e; ++i)
1037 if (UseScalarTypes ?
1038 getOperand(i)->
getType()->getScalarType() !=
1039 I->getOperand(i)->getType()->getScalarType() :
1040 getOperand(i)->
getType() !=
I->getOperand(i)->getType())
1043 return this->hasSameSpecialState(
I, IgnoreAlignment, IntersectAttrs);
1047 for (
const Use &U : uses()) {
1053 if (
I->getParent() != BB)
1065 switch (getOpcode()) {
1066 default:
return false;
1067 case Instruction::VAArg:
1068 case Instruction::Load:
1069 case Instruction::Fence:
1070 case Instruction::AtomicCmpXchg:
1071 case Instruction::AtomicRMW:
1072 case Instruction::CatchPad:
1073 case Instruction::CatchRet:
1075 case Instruction::Call:
1076 case Instruction::Invoke:
1077 case Instruction::CallBr:
1079 case Instruction::Store:
1085 switch (getOpcode()) {
1086 default:
return false;
1087 case Instruction::Fence:
1088 case Instruction::Store:
1089 case Instruction::VAArg:
1090 case Instruction::AtomicCmpXchg:
1091 case Instruction::AtomicRMW:
1092 case Instruction::CatchPad:
1093 case Instruction::CatchRet:
1095 case Instruction::Call:
1096 case Instruction::Invoke:
1097 case Instruction::CallBr:
1099 case Instruction::Load:
1105 switch (getOpcode()) {
1108 case Instruction::AtomicCmpXchg:
1109 case Instruction::AtomicRMW:
1110 case Instruction::Fence:
1112 case Instruction::Load:
1114 case Instruction::Store:
1121 switch (getOpcode()) {
1124 case Instruction::AtomicCmpXchg:
1125 case Instruction::AtomicRMW:
1126 case Instruction::Load:
1133 switch (getOpcode()) {
1136 case Instruction::AtomicCmpXchg:
1137 case Instruction::AtomicRMW:
1138 case Instruction::Store:
1144 switch (getOpcode()) {
1147 case Instruction::AtomicRMW:
1149 case Instruction::Store:
1151 case Instruction::Load:
1153 case Instruction::AtomicCmpXchg:
1155 case Instruction::Call:
1156 case Instruction::Invoke:
1160 return MI->isVolatile();
1161 switch (
II->getIntrinsicID()) {
1163 case Intrinsic::matrix_column_major_load:
1165 case Intrinsic::matrix_column_major_store:
1177 switch (getOpcode()) {
1179 assert(!isAtomic() &&
"Unhandled atomic instruction");
1181 case Instruction::Fence: {
1186 case Instruction::AtomicRMW:
1187 case Instruction::AtomicCmpXchg:
1189 case Instruction::Store:
1191 case Instruction::Load:
1193 case Instruction::Call:
1194 case Instruction::Invoke:
1195 case Instruction::CallBr:
1201 switch (getOpcode()) {
1202 case Instruction::Store:
1204 case Instruction::Load:
1205 case Instruction::AtomicRMW:
1207 case Instruction::AtomicCmpXchg:
1209 case Instruction::Call:
1210 case Instruction::Invoke:
1212 switch (
II->getIntrinsicID()) {
1213 case Intrinsic::masked_load:
1214 case Intrinsic::masked_gather:
1215 case Intrinsic::masked_expandload:
1216 case Intrinsic::vp_load:
1217 case Intrinsic::vp_gather:
1218 case Intrinsic::experimental_vp_strided_load:
1219 return II->getType();
1220 case Intrinsic::masked_store:
1221 case Intrinsic::masked_scatter:
1222 case Intrinsic::masked_compressstore:
1223 case Intrinsic::vp_store:
1224 case Intrinsic::vp_scatter:
1225 case Intrinsic::experimental_vp_strided_store:
1226 return II->getOperand(0)->getType();
1237 bool IncludePhaseOneUnwind) {
1241 return IncludePhaseOneUnwind;
1249 if (LP->
isFilter(
I) && Clause->getType()->getArrayNumElements() == 0)
1259 switch (getOpcode()) {
1260 case Instruction::Call:
1262 case Instruction::CleanupRet:
1264 case Instruction::CatchSwitch:
1266 case Instruction::Resume:
1268 case Instruction::Invoke: {
1277 case Instruction::CleanupPad:
1279 return IncludePhaseOneUnwind;
1286 return mayWriteToMemory() ||
mayThrow() || !willReturn();
1291 !this->isTerminator() && !this->isEHPad();
1300 return CB->hasFnAttr(Attribute::WillReturn);
1309 return ID == Intrinsic::lifetime_start ||
ID == Intrinsic::lifetime_end;
1317 return ID == Intrinsic::launder_invariant_group ||
1318 ID == Intrinsic::strip_invariant_group;
1331 return II->isAssociative();
1332 unsigned Opcode = getOpcode();
1349 return II->isCommutative();
1356 return II->isCommutableOperand(
Op);
1362 switch (getOpcode()) {
1363#define HANDLE_TERM_INST(N, OPC, CLASS) \
1364 case Instruction::OPC: \
1365 return static_cast<const CLASS *>(this)->getNumSuccessors();
1366#include "llvm/IR/Instruction.def"
1374 switch (getOpcode()) {
1375#define HANDLE_TERM_INST(N, OPC, CLASS) \
1376 case Instruction::OPC: \
1377 return static_cast<const CLASS *>(this)->getSuccessor(idx);
1378#include "llvm/IR/Instruction.def"
1386 switch (getOpcode()) {
1387#define HANDLE_TERM_INST(N, OPC, CLASS) \
1388 case Instruction::OPC: \
1389 return static_cast<CLASS *>(this)->setSuccessor(idx, B);
1390#include "llvm/IR/Instruction.def"
1399 switch (getOpcode()) {
1400#define HANDLE_TERM_INST(N, OPC, CLASS) \
1401 case Instruction::OPC: \
1402 return static_cast<const CLASS *>(this)->successors();
1403#include "llvm/IR/Instruction.def"
1412 for (
auto I = Succs.begin(),
E = Succs.end();
I !=
E; ++
I)
1414 I.getUse()->set(NewBB);
1429 unsigned SecondIdx = FirstIdx + 1;
1434 for (
unsigned Idx = 0; Idx < FirstIdx; ++Idx) {
1440 setMetadata(LLVMContext::MD_prof,
1458 for (
const auto &MD : TheMDs) {
1459 if (WL.
empty() || WLS.count(MD.first))
1460 setMetadata(MD.first, MD.second);
1466 switch (getOpcode()) {
1469#define HANDLE_INST(num, opc, clas) \
1470 case Instruction::opc: \
1471 New = cast<clas>(this)->cloneImpl(); \
1473#include "llvm/IR/Instruction.def"
1477 New->SubclassOptionalData = SubclassOptionalData;
1478 New->copyMetadata(*
this);
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
AMDGPU Register Bank Select
This file contains the simple types necessary to represent the attributes associated with functions a...
static const Function * getParent(const Value *V)
static GCRegistry::Add< CoreCLRGC > E("coreclr", "CoreCLR-compatible GC")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
This file contains the declarations for the subclasses of Constant, which represent the different fla...
This file defines the DenseSet and SmallDenseSet classes.
static MaybeAlign getAlign(Value *Ptr)
Module.h This file contains the declarations for the Module class.
static bool hasNoSignedWrap(BinaryOperator &I)
static bool hasNoUnsignedWrap(BinaryOperator &I)
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
Machine Check Debug Module
static DebugLoc getDebugLoc(MachineBasicBlock::instr_iterator FirstMI, MachineBasicBlock::instr_iterator LastMI)
Return the first DebugLoc that has line number information, given a range of instructions.
This file provides utility for Memory Model Relaxation Annotations (MMRAs).
uint64_t IntrinsicInst * II
StandardInstrumentations SI(Mod->getContext(), Debug, VerifyEach)
This file contains the declarations for profiling metadata utility functions.
static bool mayHaveSideEffects(MachineInstr &MI)
static bool isCommutative(Instruction *I, Value *ValWithUses, bool IsCopyable=false)
static bool canUnwindPastLandingPad(const LandingPadInst *LP, bool IncludePhaseOneUnwind)
static SymbolRef::Type getType(const Symbol *Sym)
static bool isAssociative(const COFFSection &Section)
an instruction to allocate memory on the stack
Represent a constant reference to an array (0 or more elements consecutively in memory),...
bool empty() const
Check if the array is empty.
An instruction that atomically checks whether a specified value is in a memory location,...
an instruction that atomically reads a memory location, combines it with another value,...
This class stores enough information to efficiently remove some attributes from an existing AttrBuild...
AttributeMask & addAttribute(Attribute::AttrKind Val)
Add an attribute to the mask.
This class holds the attributes for a particular argument, parameter, function, or return value.
LLVM Basic Block Representation.
LLVM_ABI void deleteTrailingDbgRecords()
Delete any trailing DbgRecords at the end of this block, see setTrailingDbgRecords.
LLVM_ABI const_iterator getFirstInsertionPt() const
Returns an iterator to the first instruction in this block that is suitable for inserting a non-PHI i...
const Function * getParent() const
Return the enclosing method, or null if none.
LLVM_ABI InstListType::const_iterator getFirstNonPHIIt() const
Returns an iterator to the first instruction in this block that is not a PHINode instruction.
LLVM_ABI DbgMarker * getMarker(InstListType::iterator It)
Return the DbgMarker for the position given by It, so that DbgRecords can be inserted there.
InstListType::iterator iterator
Instruction iterators...
Base class for all callable instructions (InvokeInst and CallInst) Holds everything related to callin...
AttributeList getAttributes() const
Return the attributes for this call.
CallBr instruction, tracking function calls that may not return control but instead transfer it to a ...
This class represents a function call, abstracting a target machine's calling convention.
This class is the base class for the comparison instructions.
static LLVM_ABI ConstantInt * getFalse(LLVMContext &Context)
A parsed version of the target data layout string in and methods for querying it.
Per-instruction record of debug-info.
static iterator_range< simple_ilist< DbgRecord >::iterator > getEmptyDbgRecordRange()
Instruction * MarkedInstr
Link back to the Instruction that owns this marker.
LLVM_ABI void eraseFromParent()
simple_ilist< DbgRecord > StoredDbgRecords
List of DbgRecords, the non-instruction equivalent of llvm.dbg.
Base class for non-instruction debug metadata records that have positions within IR.
DebugLoc orElse(DebugLoc Other) const
If this DebugLoc is non-empty, returns this DebugLoc; otherwise, selects Other.
Convenience struct for specifying and reasoning about fast-math flags.
An instruction for ordering other memory operations.
static GEPNoWrapFlags none()
an instruction for type-safe pointer arithmetic to access elements of arrays and structs
InsertPosition(std::nullptr_t)
This instruction inserts a struct field of array element value into an aggregate value.
LLVM_ABI const DebugLoc & getStableDebugLoc() const
Fetch the debug location for this node, unless this is a debug intrinsic, in which case fetch the deb...
LLVM_ABI void dropUBImplyingAttrsAndMetadata(ArrayRef< unsigned > Keep={})
Drop any attributes or metadata that can cause immediate undefined behavior.
DbgMarker * DebugMarker
Optional marker recording the position for debugging information that takes effect immediately before...
LLVM_ABI bool mayThrow(bool IncludePhaseOneUnwind=false) const LLVM_READONLY
Return true if this instruction may throw an exception.
LLVM_ABI Instruction * clone() const
Create a copy of 'this' instruction that is identical in all ways except the following:
LLVM_ABI void setHasNoUnsignedWrap(bool b=true)
Set or clear the nuw flag on this instruction, which must be an operator which supports this flag.
LLVM_ABI bool hasNoNaNs() const LLVM_READONLY
Determine whether the no-NaNs flag is set.
LLVM_ABI void removeFromParent()
This method unlinks 'this' from the containing basic block, but does not delete it.
LLVM_ABI bool hasNoUnsignedWrap() const LLVM_READONLY
Determine whether the no unsigned wrap flag is set.
LLVM_ABI bool hasNoInfs() const LLVM_READONLY
Determine whether the no-infs flag is set.
LLVM_ABI bool isLifetimeStartOrEnd() const LLVM_READONLY
Return true if the instruction is a llvm.lifetime.start or llvm.lifetime.end marker.
LLVM_ABI bool hasPoisonGeneratingAttributes() const LLVM_READONLY
Return true if this instruction has poison-generating attribute.
LLVM_ABI void copyFastMathFlags(FastMathFlags FMF)
Convenience function for transferring all fast-math flag values to this instruction,...
LLVM_ABI bool isSameOperationAs(const Instruction *I, unsigned flags=0) const LLVM_READONLY
This function determines if the specified instruction executes the same operation as the current one.
LLVM_ABI void setHasNoSignedZeros(bool B)
Set or clear the no-signed-zeros flag on this instruction, which must be an operator which supports t...
LLVM_ABI bool hasNoSignedZeros() const LLVM_READONLY
Determine whether the no-signed-zeros flag is set.
LLVM_ABI iterator_range< simple_ilist< DbgRecord >::iterator > cloneDebugInfoFrom(const Instruction *From, std::optional< simple_ilist< DbgRecord >::iterator > FromHere=std::nullopt, bool InsertAtHead=false)
Clone any debug-info attached to From onto this instruction.
LLVM_ABI bool isDebugOrPseudoInst() const LLVM_READONLY
Return true if the instruction is a DbgInfoIntrinsic or PseudoProbeInst.
LLVM_ABI unsigned getNumSuccessors() const LLVM_READONLY
Return the number of successors that this instruction has.
LLVM_ABI bool hasNoSignedWrap() const LLVM_READONLY
Determine whether the no signed wrap flag is set.
LLVM_ABI bool mayWriteToMemory() const LLVM_READONLY
Return true if this instruction may modify memory.
LLVM_ABI void copyIRFlags(const Value *V, bool IncludeWrapFlags=true)
Convenience method to copy supported exact, fast-math, and (optionally) wrapping flags from V to this...
LLVM_ABI void setHasAllowContract(bool B)
Set or clear the allow-contract flag on this instruction, which must be an operator which supports th...
LLVM_ABI bool hasAtomicStore() const LLVM_READONLY
Return true if this atomic instruction stores to memory.
LLVM_ABI void setHasNoSignedWrap(bool b=true)
Set or clear the nsw flag on this instruction, which must be an operator which supports this flag.
LLVM_ABI bool isOnlyUserOfAnyOperand()
It checks if this instruction is the only user of at least one of its operands.
const DebugLoc & getDebugLoc() const
Return the debug location for this node as a DebugLoc.
LLVM_ABI const Module * getModule() const
Return the module owning the function this instruction belongs to or nullptr it the function does not...
LLVM_ABI void andIRFlags(const Value *V)
Logical 'and' of any supported wrapping, exact, and fast-math flags of V and this instruction.
LLVM_ABI void setHasNoNaNs(bool B)
Set or clear the no-nans flag on this instruction, which must be an operator which supports this flag...
LLVM_ABI bool isAssociative() const LLVM_READONLY
Return true if the instruction is associative:
LLVM_ABI void setHasApproxFunc(bool B)
Set or clear the approximate-math-functions flag on this instruction, which must be an operator which...
LLVM_ABI void moveAfter(Instruction *MovePos)
Unlink this instruction from its current basic block and insert it into the basic block that MovePos ...
LLVM_ABI bool isCommutative() const LLVM_READONLY
Return true if the instruction is commutative:
bool hasMetadata() const
Return true if this instruction has any metadata attached to it.
LLVM_ABI bool hasSameSpecialState(const Instruction *I2, bool IgnoreAlignment=false, bool IntersectAttrs=false) const LLVM_READONLY
This function determines if the speficied instruction has the same "special" characteristics as the c...
LLVM_ABI void moveBefore(InstListType::iterator InsertPos)
Unlink this instruction from its current basic block and insert it into the basic block that MovePos ...
LLVM_ABI bool isAtomic() const LLVM_READONLY
Return true if this instruction has an AtomicOrdering of unordered or higher.
LLVM_ABI void setHasAllowReassoc(bool B)
Set or clear the reassociation flag on this instruction, which must be an operator which supports thi...
LLVM_ABI void insertBefore(InstListType::iterator InsertPos)
Insert an unlinked instruction into a basic block immediately before the specified position.
LLVM_ABI void setFastMathFlags(FastMathFlags FMF)
Convenience function for setting multiple fast-math flags on this instruction, which must be an opera...
LLVM_ABI InstListType::iterator eraseFromParent()
This method unlinks 'this' from the containing basic block and deletes it.
LLVM_ABI bool isIdenticalToWhenDefined(const Instruction *I, bool IntersectAttrs=false) const LLVM_READONLY
This is like isIdenticalTo, except that it ignores the SubclassOptionalData flags,...
LLVM_ABI bool isFast() const LLVM_READONLY
Determine whether all fast-math-flags are set.
LLVM_ABI void replaceSuccessorWith(BasicBlock *OldBB, BasicBlock *NewBB)
Replace specified successor OldBB to point at the provided block.
LLVM_ABI bool isExact() const LLVM_READONLY
Determine whether the exact flag is set.
LLVM_ABI const Function * getFunction() const
Return the function this instruction belongs to.
LLVM_ABI void swapProfMetadata()
If the instruction has "branch_weights" MD_prof metadata and the MDNode has three operands (including...
LLVM_ABI BasicBlock * getSuccessor(unsigned Idx) const LLVM_READONLY
Return the specified successor. This instruction must be a terminator.
LLVM_ABI bool mayHaveSideEffects() const LLVM_READONLY
Return true if the instruction may have side effects.
LLVM_ABI void dropOneDbgRecord(DbgRecord *I)
Erase a single DbgRecord I that is attached to this instruction.
LLVM_ABI void setNonNeg(bool b=true)
Set or clear the nneg flag on this instruction, which must be a zext instruction.
LLVM_ABI Type * getAccessType() const LLVM_READONLY
Return the type this instruction accesses in memory, if any.
LLVM_ABI bool hasAllowReciprocal() const LLVM_READONLY
Determine whether the allow-reciprocal flag is set.
LLVM_ABI bool comesBefore(const Instruction *Other) const
Given an instruction Other in the same basic block as this instruction, return true if this instructi...
LLVM_ABI bool hasNonNeg() const LLVM_READONLY
Determine whether the the nneg flag is set.
LLVM_ABI bool maySynchronize() const LLVM_READONLY
Return true if this instruction may synchronize, in the sense that it may introduce a synchronizes-wi...
LLVM_ABI bool hasPoisonGeneratingFlags() const LLVM_READONLY
Return true if this operator has flags which may cause this instruction to evaluate to poison despite...
LLVM_ABI bool mayReadFromMemory() const LLVM_READONLY
Return true if this instruction may read memory.
LLVM_ABI bool isUsedOutsideOfBlock(const BasicBlock *BB) const LLVM_READONLY
Return true if there are any uses of this instruction in blocks other than the specified block.
LLVM_ABI bool isVolatile() const LLVM_READONLY
Return true if this instruction has a volatile memory access.
LLVM_ABI void setHasNoInfs(bool B)
Set or clear the no-infs flag on this instruction, which must be an operator which supports this flag...
LLVM_ABI iterator_range< const_succ_iterator > successors() const LLVM_READONLY
LLVM_ABI void adoptDbgRecords(BasicBlock *BB, InstListType::iterator It, bool InsertAtHead)
Transfer any DbgRecords on the position It onto this instruction, by simply adopting the sequence of ...
LLVM_ABI FastMathFlags getFastMathFlags() const LLVM_READONLY
Convenience function for getting all the fast-math flags, which must be an operator which supports th...
const char * getOpcodeName() const
LLVM_ABI bool willReturn() const LLVM_READONLY
Return true if the instruction will return (unwinding is considered as a form of returning control fl...
LLVM_ABI bool hasNonDebugLocLoopMetadata() const
LLVM_ABI bool hasApproxFunc() const LLVM_READONLY
Determine whether the approximate-math-functions flag is set.
void getAllMetadataOtherThanDebugLoc(SmallVectorImpl< std::pair< unsigned, MDNode * > > &MDs) const
This does the same thing as getAllMetadata, except that it filters out the debug location.
LLVM_ABI void moveAfterPreserving(Instruction *MovePos)
See moveBeforePreserving .
unsigned getOpcode() const
Returns a member of one of the enums like Instruction::Add.
LLVM_ABI bool hasAtomicLoad() const LLVM_READONLY
Return true if this atomic instruction loads from memory.
LLVM_ABI void setIsExact(bool b=true)
Set or clear the exact flag on this instruction, which must be an operator which supports this flag.
LLVM_ABI void dropPoisonGeneratingMetadata()
Drops metadata that may generate poison.
LLVM_ABI void setHasAllowReciprocal(bool B)
Set or clear the allow-reciprocal flag on this instruction, which must be an operator which supports ...
LLVM_ABI void handleMarkerRemoval()
Handle the debug-info implications of this instruction being removed.
LLVM_ABI bool hasUBImplyingAttrs() const LLVM_READONLY
Return true if this instruction has UB-implying attributes that can cause immediate undefined behavio...
LLVM_ABI std::optional< InstListType::iterator > getInsertionPointAfterDef()
Get the first insertion point at which the result of this instruction is defined.
LLVM_ABI void dropPoisonGeneratingFlags()
Drops flags that may cause this instruction to evaluate to poison despite having non-poison inputs.
LLVM_ABI void dropPoisonGeneratingAttributes()
Drops attributes that may generate poison.
LLVM_ABI void dropUBImplyingAttrsAndUnknownMetadata(ArrayRef< unsigned > KnownIDs={})
This function drops non-debug unknown metadata (through dropUnknownNonDebugMetadata).
LLVM_ABI bool isIdenticalTo(const Instruction *I) const LLVM_READONLY
Return true if the specified instruction is exactly identical to the current one.
LLVM_ABI std::optional< simple_ilist< DbgRecord >::iterator > getDbgReinsertionPosition()
Return an iterator to the position of the "Next" DbgRecord after this instruction,...
LLVM_ABI bool isLaunderOrStripInvariantGroup() const LLVM_READONLY
Return true if the instruction is a llvm.launder.invariant.group or llvm.strip.invariant....
LLVM_ABI bool hasAllowContract() const LLVM_READONLY
Determine whether the allow-contract flag is set.
LLVM_ABI void moveBeforePreserving(InstListType::iterator MovePos)
Perform a moveBefore operation, while signalling that the caller intends to preserve the original ord...
LLVM_ABI bool hasPoisonGeneratingMetadata() const LLVM_READONLY
Return true if this instruction has poison-generating metadata.
Instruction(const Instruction &)=delete
LLVM_ABI void setSuccessor(unsigned Idx, BasicBlock *BB)
Update the specified successor to point at the provided block.
LLVM_ABI bool isCommutableOperand(unsigned Op) const LLVM_READONLY
Checks if the operand is commutative.
LLVM_ABI void copyMetadata(const Instruction &SrcInst, ArrayRef< unsigned > WL=ArrayRef< unsigned >())
Copy metadata from SrcInst to this instruction.
LLVM_ABI void setFast(bool B)
Set or clear all fast-math-flags on this instruction, which must be an operator which supports this f...
LLVM_ABI bool hasAllowReassoc() const LLVM_READONLY
Determine whether the allow-reassociation flag is set.
LLVM_ABI void dropDbgRecords()
Erase any DbgRecords attached to this instruction.
LLVM_ABI void insertAfter(Instruction *InsertPos)
Insert an unlinked instruction into a basic block immediately after the specified instruction.
LLVM_ABI const DataLayout & getDataLayout() const
Get the data layout of the module this instruction belongs to.
LLVM_ABI bool isSafeToRemove() const LLVM_READONLY
Return true if the instruction can be removed if the result is unused.
LLVM_ABI InstListType::iterator insertInto(BasicBlock *ParentBB, InstListType::iterator It)
Inserts an unlinked instruction into ParentBB at position It and returns the iterator of the inserted...
LLVM_ABI bool hasDbgRecords() const
Returns true if any DbgRecords are attached to this instruction.
A wrapper class for inspecting calls to intrinsic functions.
The landingpad instruction holds all of the information necessary to generate correct exception handl...
bool isCleanup() const
Return 'true' if this landingpad instruction is a cleanup.
unsigned getNumClauses() const
Get the number of clauses for this landing pad.
bool isCatch(unsigned Idx) const
Return 'true' if the clause and index Idx is a catch clause.
bool isFilter(unsigned Idx) const
Return 'true' if the clause and index Idx is a filter clause.
Constant * getClause(unsigned Idx) const
Get the value of the clause at index Idx.
An instruction for reading from memory.
const MDOperand & getOperand(unsigned I) const
ArrayRef< MDOperand > operands() const
static MDTuple * get(LLVMContext &Context, ArrayRef< Metadata * > MDs)
unsigned getNumOperands() const
Return number of MDNode operands.
LLVMContext & getContext() const
Tracking metadata reference owned by Metadata.
iterator_range< const_block_iterator > blocks() const
BasicBlock * getIncomingBlock(unsigned i) const
Return incoming basic block number i.
static LLVM_ABI PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
Instruction that can have a nneg flag (zext/uitofp).
This instruction constructs a fixed permutation of two input vectors.
Implements a dense probed hash-table based set with some number of buckets stored inline.
void reserve(size_type N)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
An instruction for storing to memory.
A Use represents the edge between a Value definition and its users.
LLVMContext & getContext() const
All values hold a context through their type.
const ParentTy * getParent() const
self_iterator getIterator()
void splice(iterator where, iplist_impl &L2)
iterator insertAfter(iterator where, pointer New)
iterator insert(iterator where, pointer New)
A range adaptor for a pair of iterators.
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
constexpr char Attrs[]
Key for Kernel::Metadata::mAttrs.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
@ SingleThread
Synchronized with respect to signal handlers executing in the same thread.
bool mayThrow(const MachineInstr &MI)
@ OB
OB - OneByte - Set if this instruction has a one byte opcode.
initializer< Ty > init(const Ty &Val)
@ Switch
The "resume-switch" lowering, where there are separate resume and destroy functions that are shared b...
NodeAddr< PhiNode * > Phi
Context & getContext() const
This is an optimization pass for GlobalISel generic memory operations.
auto drop_begin(T &&RangeOrContainer, size_t N=1)
Return a range covering RangeOrContainer with the first N elements excluded.
detail::zippy< detail::zip_shortest, T, U, Args... > zip(T &&t, U &&u, Args &&...args)
zip iterator for two or more iteratable types.
cl::opt< bool > ProfcheckDisableMetadataFixes
LLVM_ABI unsigned getBranchWeightOffset(const MDNode *ProfileData)
Return the offset to the first branch weight data.
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
auto successors(const MachineBasicBlock *BB)
LLVM_ABI MDNode * getBranchWeightMDNode(const Instruction &I)
Get the branch weights metadata node.
void append_range(Container &C, Range &&R)
Wrapper function to append range R to container C.
bool isStrongerThanUnordered(AtomicOrdering AO)
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
iterator_range< simple_ilist< DbgRecord >::iterator > getDbgRecordRange(DbgMarker *DebugMarker)
Inline helper to return a range of DbgRecords attached to a marker.
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...
auto drop_end(T &&RangeOrContainer, size_t N=1)
Return a range covering RangeOrContainer with the last N elements excluded.
@ FSub
Subtraction of floats.
@ Xor
Bitwise or logical XOR of integers.
@ Sub
Subtraction of integers.
DWARFExpression::Operation Op
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
bool equal(L &&LRange, R &&RRange)
Wrapper function around std::equal to detect if pair-wise elements between two ranges are the same.
@ Keep
No function return thunk.
Summary of memprof metadata on allocations.