LLVM 23.0.0git
IntrinsicInst.cpp
Go to the documentation of this file.
1//===-- IntrinsicInst.cpp - Intrinsic Instruction Wrappers ---------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8//
9// This file implements methods that make it really easy to deal with intrinsic
10// functions.
11//
12// All intrinsic function calls are instances of the call instruction, so these
13// are all subclasses of the CallInst class. Note that none of these classes
14// has state or virtual methods, which is an important part of this gross/neat
15// hack working.
16//
17// In some cases, arguments to intrinsics need to be generic and are defined as
18// type pointer to empty struct { }*. To access the real item of interest the
19// cast instruction needs to be stripped away.
20//
21//===----------------------------------------------------------------------===//
22
25#include "llvm/IR/Constants.h"
27#include "llvm/IR/Metadata.h"
28#include "llvm/IR/Module.h"
29#include "llvm/IR/Operator.h"
31#include "llvm/IR/Statepoint.h"
32#include <optional>
33
34using namespace llvm;
35
37 switch (IID) {
38 case Intrinsic::objc_autorelease:
39 case Intrinsic::objc_autoreleasePoolPop:
40 case Intrinsic::objc_autoreleasePoolPush:
41 case Intrinsic::objc_autoreleaseReturnValue:
42 case Intrinsic::objc_claimAutoreleasedReturnValue:
43 case Intrinsic::objc_copyWeak:
44 case Intrinsic::objc_destroyWeak:
45 case Intrinsic::objc_initWeak:
46 case Intrinsic::objc_loadWeak:
47 case Intrinsic::objc_loadWeakRetained:
48 case Intrinsic::objc_moveWeak:
49 case Intrinsic::objc_release:
50 case Intrinsic::objc_retain:
51 case Intrinsic::objc_retainAutorelease:
52 case Intrinsic::objc_retainAutoreleaseReturnValue:
53 case Intrinsic::objc_retainAutoreleasedReturnValue:
54 case Intrinsic::objc_retainBlock:
55 case Intrinsic::objc_storeStrong:
56 case Intrinsic::objc_storeWeak:
57 case Intrinsic::objc_unsafeClaimAutoreleasedReturnValue:
58 case Intrinsic::objc_retainedObject:
59 case Intrinsic::objc_unretainedObject:
60 case Intrinsic::objc_unretainedPointer:
61 case Intrinsic::objc_retain_autorelease:
62 case Intrinsic::objc_sync_enter:
63 case Intrinsic::objc_sync_exit:
64 return true;
65 default:
66 return false;
67 }
68}
69
70//===----------------------------------------------------------------------===//
71/// DbgVariableIntrinsic - This is the common base class for debug info
72/// intrinsics for variables.
73///
74
77 assert(MD && "First operand of DbgVariableIntrinsic should be non-null.");
78 // If operand is ValueAsMetadata, return a range over just that operand.
79 if (auto *VAM = dyn_cast<ValueAsMetadata>(MD)) {
80 return {location_op_iterator(VAM), location_op_iterator(VAM + 1)};
81 }
82 // If operand is DIArgList, return a range over its args.
83 if (auto *AL = dyn_cast<DIArgList>(MD))
84 return {location_op_iterator(AL->args_begin()),
85 location_op_iterator(AL->args_end())};
86 // Operand must be an empty metadata tuple, so return empty iterator.
87 return {location_op_iterator(static_cast<ValueAsMetadata *>(nullptr)),
88 location_op_iterator(static_cast<ValueAsMetadata *>(nullptr))};
89}
90
95
99
101 Metadata *MD = getRawLocation();
102 assert(MD && "First operand of DbgVariableIntrinsic should be non-null.");
103 if (auto *AL = dyn_cast<DIArgList>(MD))
104 return AL->getArgs()[OpIdx]->getValue();
105 if (isa<MDNode>(MD))
106 return nullptr;
107 assert(
109 "Attempted to get location operand from DbgVariableIntrinsic with none.");
110 auto *V = cast<ValueAsMetadata>(MD);
111 assert(OpIdx == 0 && "Operand Index must be 0 for a debug intrinsic with a "
112 "single location operand.");
113 return V->getValue();
114}
115
121
123 Value *NewValue,
124 bool AllowEmpty) {
125 // If OldValue is used as the address part of a dbg.assign intrinsic replace
126 // it with NewValue and return true.
127 auto ReplaceDbgAssignAddress = [this, OldValue, NewValue]() -> bool {
128 auto *DAI = dyn_cast<DbgAssignIntrinsic>(this);
129 if (!DAI || OldValue != DAI->getAddress())
130 return false;
131 DAI->setAddress(NewValue);
132 return true;
133 };
134 bool DbgAssignAddrReplaced = ReplaceDbgAssignAddress();
135 (void)DbgAssignAddrReplaced;
136
137 assert(NewValue && "Values must be non-null");
138 auto Locations = location_ops();
139 auto OldIt = find(Locations, OldValue);
140 if (OldIt == Locations.end()) {
141 if (AllowEmpty || DbgAssignAddrReplaced)
142 return;
143 assert(DbgAssignAddrReplaced &&
144 "OldValue must be dbg.assign addr if unused in DIArgList");
145 return;
146 }
147
148 assert(OldIt != Locations.end() && "OldValue must be a current location");
149 if (!hasArgList()) {
150 Value *NewOperand = isa<MetadataAsValue>(NewValue)
151 ? NewValue
153 getContext(), ValueAsMetadata::get(NewValue));
154 return setArgOperand(0, NewOperand);
155 }
157 ValueAsMetadata *NewOperand = getAsMetadata(NewValue);
158 for (auto *VMD : Locations)
159 MDs.push_back(VMD == *OldIt ? NewOperand : getAsMetadata(VMD));
162}
164 Value *NewValue) {
165 assert(OpIdx < getNumVariableLocationOps() && "Invalid Operand Index");
166 if (!hasArgList()) {
167 Value *NewOperand = isa<MetadataAsValue>(NewValue)
168 ? NewValue
170 getContext(), ValueAsMetadata::get(NewValue));
171 return setArgOperand(0, NewOperand);
172 }
174 ValueAsMetadata *NewOperand = getAsMetadata(NewValue);
175 for (unsigned Idx = 0; Idx < getNumVariableLocationOps(); ++Idx)
176 MDs.push_back(Idx == OpIdx ? NewOperand
180}
181
184 assert(NewExpr->hasAllLocationOps(getNumVariableLocationOps() +
185 NewValues.size()) &&
186 "NewExpr for debug variable intrinsic does not reference every "
187 "location operand.");
188 assert(!is_contained(NewValues, nullptr) && "New values must be non-null");
191 for (auto *VMD : location_ops())
192 MDs.push_back(getAsMetadata(VMD));
193 for (auto *VMD : NewValues)
194 MDs.push_back(getAsMetadata(VMD));
197}
198
199std::optional<uint64_t> DbgVariableIntrinsic::getFragmentSizeInBits() const {
200 if (auto Fragment = getExpression()->getFragmentInfo())
201 return Fragment->SizeInBits;
202 return getVariable()->getSizeInBits();
203}
204
206 auto *MD = getRawAddress();
207 if (auto *V = dyn_cast<ValueAsMetadata>(MD))
208 return V->getValue();
209
210 // When the value goes to null, it gets replaced by an empty MDNode.
211 assert(!cast<MDNode>(MD)->getNumOperands() && "Expected an empty MDNode");
212 return nullptr;
213}
214
218
223
229
231 Value *Addr = getAddress();
232 return !Addr || isa<UndefValue>(Addr);
233}
234
239
242 llvm_unreachable("InstrProfValueProfileInst does not have counters!");
244}
245
248 llvm_unreachable("Please use InstrProfValueProfileInst::getIndex()");
250}
251
256
259 return getArgOperand(4);
260 }
261 const Module *M = getModule();
262 LLVMContext &Context = M->getContext();
263 return ConstantInt::get(Type::getInt64Ty(Context), 1);
264}
265
267
270 setArgOperand(4, Callee);
271}
272
273std::optional<RoundingMode> ConstrainedFPIntrinsic::getRoundingMode() const {
274 unsigned NumOperands = arg_size();
275 Metadata *MD = nullptr;
276 auto *MAV = dyn_cast<MetadataAsValue>(getArgOperand(NumOperands - 2));
277 if (MAV)
278 MD = MAV->getMetadata();
279 if (!MD || !isa<MDString>(MD))
280 return std::nullopt;
281 return convertStrToRoundingMode(cast<MDString>(MD)->getString());
282}
283
284std::optional<fp::ExceptionBehavior>
286 unsigned NumOperands = arg_size();
287 Metadata *MD = nullptr;
288 auto *MAV = dyn_cast<MetadataAsValue>(getArgOperand(NumOperands - 1));
289 if (MAV)
290 MD = MAV->getMetadata();
291 if (!MD || !isa<MDString>(MD))
292 return std::nullopt;
293 return convertStrToExceptionBehavior(cast<MDString>(MD)->getString());
294}
295
297 std::optional<fp::ExceptionBehavior> Except = getExceptionBehavior();
298 if (Except) {
299 if (*Except != fp::ebIgnore)
300 return false;
301 }
302
303 std::optional<RoundingMode> Rounding = getRoundingMode();
304 if (Rounding) {
305 if (*Rounding != RoundingMode::NearestTiesToEven)
306 return false;
307 }
308
309 return true;
310}
311
333
337
339 // All constrained fp intrinsics have "fpexcept" metadata.
340 unsigned NumArgs = arg_size() - 1;
341
342 // Some intrinsics have "round" metadata.
344 NumArgs -= 1;
345
346 // Compare intrinsics take their predicate as metadata.
348 NumArgs -= 1;
349
350 return NumArgs;
351}
352
356
358 auto GetVectorLengthOfType = [](const Type *T) -> ElementCount {
359 const auto *VT = cast<VectorType>(T);
360 auto ElemCount = VT->getElementCount();
361 return ElemCount;
362 };
363
364 Value *VPMask = getMaskParam();
365 if (!VPMask) {
366 assert((getIntrinsicID() == Intrinsic::vp_merge ||
367 getIntrinsicID() == Intrinsic::vp_select) &&
368 "Unexpected VP intrinsic without mask operand");
369 return GetVectorLengthOfType(getType());
370 }
371 return GetVectorLengthOfType(VPMask->getType());
372}
373
375 if (auto MaskPos = getMaskParamPos(getIntrinsicID()))
376 return getArgOperand(*MaskPos);
377 return nullptr;
378}
379
381 auto MaskPos = getMaskParamPos(getIntrinsicID());
382 setArgOperand(*MaskPos, NewMask);
383}
384
386 if (auto EVLPos = getVectorLengthParamPos(getIntrinsicID()))
387 return getArgOperand(*EVLPos);
388 return nullptr;
389}
390
393 setArgOperand(*EVLPos, NewEVL);
394}
395
396std::optional<unsigned>
398 switch (IntrinsicID) {
399 default:
400 return std::nullopt;
401
402#define BEGIN_REGISTER_VP_INTRINSIC(VPID, MASKPOS, VLENPOS) \
403 case Intrinsic::VPID: \
404 return MASKPOS;
405#include "llvm/IR/VPIntrinsics.def"
406 }
407}
408
409std::optional<unsigned>
411 switch (IntrinsicID) {
412 default:
413 return std::nullopt;
414
415#define BEGIN_REGISTER_VP_INTRINSIC(VPID, MASKPOS, VLENPOS) \
416 case Intrinsic::VPID: \
417 return VLENPOS;
418#include "llvm/IR/VPIntrinsics.def"
419 }
420}
421
422/// \return the alignment of the pointer used by this load/store/gather or
423/// scatter.
425 std::optional<unsigned> PtrParamOpt =
427 assert(PtrParamOpt && "no pointer argument!");
428 return getParamAlign(*PtrParamOpt);
429}
430
431/// \return The pointer operand of this load,store, gather or scatter.
433 if (auto PtrParamOpt = getMemoryPointerParamPos(getIntrinsicID()))
434 return getArgOperand(*PtrParamOpt);
435 return nullptr;
436}
437
438std::optional<unsigned>
440 switch (VPID) {
441 default:
442 return std::nullopt;
443 case Intrinsic::vp_store:
444 case Intrinsic::vp_scatter:
445 case Intrinsic::experimental_vp_strided_store:
446 return 1;
447 case Intrinsic::vp_load:
448 case Intrinsic::vp_load_ff:
449 case Intrinsic::vp_gather:
450 case Intrinsic::experimental_vp_strided_load:
451 return 0;
452 }
453}
454
455/// \return The data (payload) operand of this store or scatter.
457 auto DataParamOpt = getMemoryDataParamPos(getIntrinsicID());
458 if (!DataParamOpt)
459 return nullptr;
460 return getArgOperand(*DataParamOpt);
461}
462
464 switch (VPID) {
465 default:
466 return std::nullopt;
467 case Intrinsic::vp_store:
468 case Intrinsic::vp_scatter:
469 case Intrinsic::experimental_vp_strided_store:
470 return 0;
471 }
472}
473
475 switch (ID) {
476 default:
477 break;
478#define BEGIN_REGISTER_VP_INTRINSIC(VPID, MASKPOS, VLENPOS) \
479 case Intrinsic::VPID: \
480 return true;
481#include "llvm/IR/VPIntrinsics.def"
482 }
483 return false;
484}
485
487 return ::isVPIntrinsic(ID);
488}
489
490// Equivalent non-predicated opcode
491constexpr static std::optional<unsigned>
493 switch (ID) {
494 default:
495 break;
496#define BEGIN_REGISTER_VP_INTRINSIC(VPID, ...) case Intrinsic::VPID:
497#define VP_PROPERTY_FUNCTIONAL_OPC(OPC) return Instruction::OPC;
498#define END_REGISTER_VP_INTRINSIC(VPID) break;
499#include "llvm/IR/VPIntrinsics.def"
500 }
501 return std::nullopt;
502}
503
504std::optional<unsigned>
506 return ::getFunctionalOpcodeForVP(ID);
507}
508
509// Equivalent non-predicated intrinsic ID
510constexpr static std::optional<Intrinsic::ID>
512 switch (ID) {
513 default:
514 break;
515#define BEGIN_REGISTER_VP_INTRINSIC(VPID, ...) case Intrinsic::VPID:
516#define VP_PROPERTY_FUNCTIONAL_INTRINSIC(INTRIN) return Intrinsic::INTRIN;
517#define END_REGISTER_VP_INTRINSIC(VPID) break;
518#include "llvm/IR/VPIntrinsics.def"
519 }
520 return std::nullopt;
521}
522
523std::optional<Intrinsic::ID>
525 return ::getFunctionalIntrinsicIDForVP(ID);
526}
527
529 switch (ID) {
530 default:
531 break;
532#define BEGIN_REGISTER_VP_INTRINSIC(VPID, ...) case Intrinsic::VPID:
533#define VP_PROPERTY_NO_FUNCTIONAL return true;
534#define END_REGISTER_VP_INTRINSIC(VPID) break;
535#include "llvm/IR/VPIntrinsics.def"
536 }
537 return false;
538}
539
540// All VP intrinsics should have an equivalent non-VP opcode or intrinsic
541// defined, or be marked that they don't have one.
542#define BEGIN_REGISTER_VP_INTRINSIC(VPID, ...) \
543 static_assert(doesVPHaveNoFunctionalEquivalent(Intrinsic::VPID) || \
544 getFunctionalOpcodeForVP(Intrinsic::VPID) || \
545 getFunctionalIntrinsicIDForVP(Intrinsic::VPID));
546#include "llvm/IR/VPIntrinsics.def"
547
548// Equivalent non-predicated constrained intrinsic
549std::optional<Intrinsic::ID>
551 switch (ID) {
552 default:
553 break;
554#define BEGIN_REGISTER_VP_INTRINSIC(VPID, ...) case Intrinsic::VPID:
555#define VP_PROPERTY_CONSTRAINEDFP(CID) return Intrinsic::CID;
556#define END_REGISTER_VP_INTRINSIC(VPID) break;
557#include "llvm/IR/VPIntrinsics.def"
558 }
559 return std::nullopt;
560}
561
563 switch (IROPC) {
564 default:
565 break;
566
567#define BEGIN_REGISTER_VP_INTRINSIC(VPID, ...) break;
568#define VP_PROPERTY_FUNCTIONAL_OPC(OPC) case Instruction::OPC:
569#define END_REGISTER_VP_INTRINSIC(VPID) return Intrinsic::VPID;
570#include "llvm/IR/VPIntrinsics.def"
571 }
573}
574
576 if (::isVPIntrinsic(Id))
577 return Id;
578
579 switch (Id) {
580 default:
581 break;
582#define BEGIN_REGISTER_VP_INTRINSIC(VPID, ...) break;
583#define VP_PROPERTY_FUNCTIONAL_INTRINSIC(INTRIN) case Intrinsic::INTRIN:
584#define END_REGISTER_VP_INTRINSIC(VPID) return Intrinsic::VPID;
585#include "llvm/IR/VPIntrinsics.def"
586 }
588}
589
591 return ::getForIntrinsic(Id);
592}
593
595 using namespace PatternMatch;
596
598
599 // No vlen param - no lanes masked-off by it.
600 auto *VLParam = getVectorLengthParam();
601 if (!VLParam)
602 return true;
603
604 // Note that the VP intrinsic causes undefined behavior if the Explicit Vector
605 // Length parameter is strictly greater-than the number of vector elements of
606 // the operation. This function returns true when this is detected statically
607 // in the IR.
608
609 // Check whether "W == vscale * EC.getKnownMinValue()"
610 if (EC.isScalable()) {
611 // Compare vscale patterns
612 uint64_t VScaleFactor;
613 if (match(VLParam, m_Mul(m_VScale(), m_ConstantInt(VScaleFactor))))
614 return VScaleFactor >= EC.getKnownMinValue();
615 return (EC.getKnownMinValue() == 1) && match(VLParam, m_VScale());
616 }
617
618 // standard SIMD operation
619 const auto *VLConst = dyn_cast<ConstantInt>(VLParam);
620 if (!VLConst)
621 return false;
622
623 uint64_t VLNum = VLConst->getZExtValue();
624 if (VLNum >= EC.getKnownMinValue())
625 return true;
626
627 return false;
628}
629
631 Module *M, Intrinsic::ID VPID, Type *ReturnType, ArrayRef<Value *> Params) {
632 assert(isVPIntrinsic(VPID) && "not a VP intrinsic");
633 Function *VPFunc;
634 switch (VPID) {
635 default: {
636 Type *OverloadTy = Params[0]->getType();
638 OverloadTy =
639 Params[*VPReductionIntrinsic::getVectorParamPos(VPID)]->getType();
640
641 VPFunc = Intrinsic::getOrInsertDeclaration(M, VPID, OverloadTy);
642 break;
643 }
644 case Intrinsic::vp_trunc:
645 case Intrinsic::vp_sext:
646 case Intrinsic::vp_zext:
647 case Intrinsic::vp_fptoui:
648 case Intrinsic::vp_fptosi:
649 case Intrinsic::vp_uitofp:
650 case Intrinsic::vp_sitofp:
651 case Intrinsic::vp_fptrunc:
652 case Intrinsic::vp_fpext:
653 case Intrinsic::vp_ptrtoint:
654 case Intrinsic::vp_inttoptr:
655 case Intrinsic::vp_lrint:
656 case Intrinsic::vp_llrint:
657 case Intrinsic::vp_cttz_elts:
659 M, VPID, {ReturnType, Params[0]->getType()});
660 break;
661 case Intrinsic::vp_is_fpclass:
662 VPFunc = Intrinsic::getOrInsertDeclaration(M, VPID, {Params[0]->getType()});
663 break;
664 case Intrinsic::vp_merge:
665 case Intrinsic::vp_select:
666 VPFunc = Intrinsic::getOrInsertDeclaration(M, VPID, {Params[1]->getType()});
667 break;
668 case Intrinsic::vp_load:
670 M, VPID, {ReturnType, Params[0]->getType()});
671 break;
672 case Intrinsic::vp_load_ff:
674 M, VPID, {ReturnType->getStructElementType(0), Params[0]->getType()});
675 break;
676 case Intrinsic::experimental_vp_strided_load:
678 M, VPID, {ReturnType, Params[0]->getType(), Params[1]->getType()});
679 break;
680 case Intrinsic::vp_gather:
682 M, VPID, {ReturnType, Params[0]->getType()});
683 break;
684 case Intrinsic::vp_store:
686 M, VPID, {Params[0]->getType(), Params[1]->getType()});
687 break;
688 case Intrinsic::experimental_vp_strided_store:
690 M, VPID,
691 {Params[0]->getType(), Params[1]->getType(), Params[2]->getType()});
692 break;
693 case Intrinsic::vp_scatter:
695 M, VPID, {Params[0]->getType(), Params[1]->getType()});
696 break;
697 }
698 assert(VPFunc && "Could not declare VP intrinsic");
699 return VPFunc;
700}
701
703 switch (ID) {
704 case Intrinsic::vp_reduce_add:
705 case Intrinsic::vp_reduce_mul:
706 case Intrinsic::vp_reduce_and:
707 case Intrinsic::vp_reduce_or:
708 case Intrinsic::vp_reduce_xor:
709 case Intrinsic::vp_reduce_smax:
710 case Intrinsic::vp_reduce_smin:
711 case Intrinsic::vp_reduce_umax:
712 case Intrinsic::vp_reduce_umin:
713 case Intrinsic::vp_reduce_fmax:
714 case Intrinsic::vp_reduce_fmin:
715 case Intrinsic::vp_reduce_fmaximum:
716 case Intrinsic::vp_reduce_fminimum:
717 case Intrinsic::vp_reduce_fadd:
718 case Intrinsic::vp_reduce_fmul:
719 return true;
720 default:
721 return false;
722 }
723}
724
726 // All of the vp.casts correspond to instructions
727 if (std::optional<unsigned> Opc = getFunctionalOpcodeForVP(ID))
728 return Instruction::isCast(*Opc);
729 return false;
730}
731
733 switch (ID) {
734 default:
735 return false;
736 case Intrinsic::vp_fcmp:
737 case Intrinsic::vp_icmp:
738 return true;
739 }
740}
741
743 switch (ID) {
744 default:
745 break;
746#define BEGIN_REGISTER_VP_INTRINSIC(VPID, ...) case Intrinsic::VPID:
747#define VP_PROPERTY_BINARYOP return true;
748#define END_REGISTER_VP_INTRINSIC(VPID) break;
749#include "llvm/IR/VPIntrinsics.def"
750 }
751 return false;
752}
753
771
778
782
786
787std::optional<unsigned>
789 if (isVPReduction(ID))
790 return 1;
791 return std::nullopt;
792}
793
794std::optional<unsigned>
796 if (isVPReduction(ID))
797 return 0;
798 return std::nullopt;
799}
800
802 switch (getIntrinsicID()) {
803 case Intrinsic::uadd_with_overflow:
804 case Intrinsic::sadd_with_overflow:
805 case Intrinsic::uadd_sat:
806 case Intrinsic::sadd_sat:
807 return Instruction::Add;
808 case Intrinsic::usub_with_overflow:
809 case Intrinsic::ssub_with_overflow:
810 case Intrinsic::usub_sat:
811 case Intrinsic::ssub_sat:
812 return Instruction::Sub;
813 case Intrinsic::umul_with_overflow:
814 case Intrinsic::smul_with_overflow:
815 return Instruction::Mul;
816 default:
817 llvm_unreachable("Invalid intrinsic");
818 }
819}
820
822 switch (getIntrinsicID()) {
823 case Intrinsic::sadd_with_overflow:
824 case Intrinsic::ssub_with_overflow:
825 case Intrinsic::smul_with_overflow:
826 case Intrinsic::sadd_sat:
827 case Intrinsic::ssub_sat:
828 return true;
829 default:
830 return false;
831 }
832}
833
840
842 const Value *Token = getArgOperand(0);
843 if (isa<UndefValue>(Token))
844 return Token;
845
846 // Treat none token as if it was undef here
847 if (isa<ConstantTokenNone>(Token))
848 return UndefValue::get(Token->getType());
849
850 // This takes care both of relocates for call statepoints and relocates
851 // on normal path of invoke statepoint.
852 if (!isa<LandingPadInst>(Token))
853 return cast<GCStatepointInst>(Token);
854
855 // This relocate is on exceptional path of an invoke statepoint
856 const BasicBlock *InvokeBB =
857 cast<Instruction>(Token)->getParent()->getUniquePredecessor();
858
859 assert(InvokeBB && "safepoints should have unique landingpads");
860 assert(InvokeBB->getTerminator() &&
861 "safepoint block should be well formed");
862
863 return cast<GCStatepointInst>(InvokeBB->getTerminator());
864}
865
867 auto Statepoint = getStatepoint();
868 if (isa<UndefValue>(Statepoint))
869 return UndefValue::get(Statepoint->getType());
870
871 auto *GCInst = cast<GCStatepointInst>(Statepoint);
872 if (auto Opt = GCInst->getOperandBundle(LLVMContext::OB_gc_live))
873 return *(Opt->Inputs.begin() + getBasePtrIndex());
874 return *(GCInst->arg_begin() + getBasePtrIndex());
875}
876
878 auto *Statepoint = getStatepoint();
879 if (isa<UndefValue>(Statepoint))
880 return UndefValue::get(Statepoint->getType());
881
882 auto *GCInst = cast<GCStatepointInst>(Statepoint);
883 if (auto Opt = GCInst->getOperandBundle(LLVMContext::OB_gc_live))
884 return *(Opt->Inputs.begin() + getDerivedPtrIndex());
885 return *(GCInst->arg_begin() + getDerivedPtrIndex());
886}
887
889 Module *M = BB.getModule();
891 M, llvm::Intrinsic::experimental_convergence_anchor);
892 auto *Call = CallInst::Create(Fn, "", BB.getFirstInsertionPt());
894}
895
897 Module *M = BB.getModule();
899 M, llvm::Intrinsic::experimental_convergence_entry);
900 auto *Call = CallInst::Create(Fn, "", BB.getFirstInsertionPt());
902}
903
906 ConvergenceControlInst *ParentToken) {
907 Module *M = BB.getModule();
909 M, llvm::Intrinsic::experimental_convergence_loop);
910 llvm::Value *BundleArgs[] = {ParentToken};
911 llvm::OperandBundleDef OB("convergencectrl", BundleArgs);
912 auto *Call = CallInst::Create(Fn, {}, {OB}, "", BB.getFirstInsertionPt());
914}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
This file contains the declarations for the subclasses of Constant, which represent the different fla...
static ValueAsMetadata * getAsMetadata(Value *V)
Module.h This file contains the declarations for the Module class.
static constexpr std::optional< Intrinsic::ID > getFunctionalIntrinsicIDForVP(Intrinsic::ID ID)
static constexpr std::optional< unsigned > getFunctionalOpcodeForVP(Intrinsic::ID ID)
static ICmpInst::Predicate getIntPredicateFromMD(const Value *Op)
static constexpr bool doesVPHaveNoFunctionalEquivalent(Intrinsic::ID ID)
constexpr bool isVPIntrinsic(Intrinsic::ID ID)
static constexpr Intrinsic::ID getForIntrinsic(Intrinsic::ID Id)
static FCmpInst::Predicate getFPPredicateFromMD(const Value *Op)
#define I(x, y, z)
Definition MD5.cpp:57
This file contains the declarations for metadata subclasses.
#define T
MachineInstr unsigned OpIdx
This file implements the StringSwitch template, which mimics a switch() statement whose cases are str...
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
size_t size() const
Get the array size.
Definition ArrayRef.h:141
LLVM Basic Block Representation.
Definition BasicBlock.h:62
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.
Definition BasicBlock.h:213
const Instruction * getTerminator() const LLVM_READONLY
Returns the terminator instruction; assumes that the block is well-formed.
Definition BasicBlock.h:237
LLVM_ABI const Module * getModule() const
Return the module owning the function this basic block belongs to, or nullptr if the function does no...
LLVM_ABI unsigned getNoWrapKind() const
Returns one of OBO::NoSignedWrap or OBO::NoUnsignedWrap.
LLVM_ABI bool isSigned() const
Whether the intrinsic is signed or unsigned.
LLVM_ABI Instruction::BinaryOps getBinaryOp() const
Returns the binary operation underlying the intrinsic.
MaybeAlign getParamAlign(unsigned ArgNo) const
Extract the alignment for a call or parameter (0=unknown).
Value * getArgOperand(unsigned i) const
void setArgOperand(unsigned i, Value *v)
unsigned arg_size() const
static CallInst * Create(FunctionType *Ty, Value *F, const Twine &NameStr="", InsertPosition InsertBefore=nullptr)
Predicate
This enumeration lists the possible predicates for CmpInst subclasses.
Definition InstrTypes.h:740
@ FCMP_OEQ
0 0 0 1 True if ordered and equal
Definition InstrTypes.h:743
@ ICMP_SLT
signed less than
Definition InstrTypes.h:769
@ ICMP_SLE
signed less or equal
Definition InstrTypes.h:770
@ FCMP_OLT
0 1 0 0 True if ordered and less than
Definition InstrTypes.h:746
@ FCMP_ULE
1 1 0 1 True if unordered, less than, or equal
Definition InstrTypes.h:755
@ FCMP_OGT
0 0 1 0 True if ordered and greater than
Definition InstrTypes.h:744
@ FCMP_OGE
0 0 1 1 True if ordered and greater than or equal
Definition InstrTypes.h:745
@ ICMP_UGE
unsigned greater or equal
Definition InstrTypes.h:764
@ ICMP_UGT
unsigned greater than
Definition InstrTypes.h:763
@ ICMP_SGT
signed greater than
Definition InstrTypes.h:767
@ FCMP_ULT
1 1 0 0 True if unordered or less than
Definition InstrTypes.h:754
@ FCMP_ONE
0 1 1 0 True if ordered and operands are unequal
Definition InstrTypes.h:748
@ FCMP_UEQ
1 0 0 1 True if unordered or equal
Definition InstrTypes.h:751
@ ICMP_ULT
unsigned less than
Definition InstrTypes.h:765
@ FCMP_UGT
1 0 1 0 True if unordered or greater than
Definition InstrTypes.h:752
@ FCMP_OLE
0 1 0 1 True if ordered and less than or equal
Definition InstrTypes.h:747
@ FCMP_ORD
0 1 1 1 True if ordered (no nans)
Definition InstrTypes.h:749
@ ICMP_NE
not equal
Definition InstrTypes.h:762
@ ICMP_SGE
signed greater or equal
Definition InstrTypes.h:768
@ FCMP_UNE
1 1 1 0 True if unordered or not equal
Definition InstrTypes.h:756
@ ICMP_ULE
unsigned less or equal
Definition InstrTypes.h:766
@ FCMP_UGE
1 0 1 1 True if unordered, greater than, or equal
Definition InstrTypes.h:753
@ FCMP_UNO
1 0 0 0 True if unordered: isnan(X) | isnan(Y)
Definition InstrTypes.h:750
This is the shared class of boolean and integer constants.
Definition Constants.h:87
LLVM_ABI FCmpInst::Predicate getPredicate() const
LLVM_ABI std::optional< fp::ExceptionBehavior > getExceptionBehavior() const
LLVM_ABI std::optional< RoundingMode > getRoundingMode() const
LLVM_ABI unsigned getNonMetadataArgCount() const
static LLVM_ABI bool classof(const IntrinsicInst *I)
LLVM_ABI bool isDefaultFPEnvironment() const
Represents calls to the llvm.experimintal.convergence.* intrinsics.
static LLVM_ABI ConvergenceControlInst * CreateAnchor(BasicBlock &BB)
static LLVM_ABI ConvergenceControlInst * CreateLoop(BasicBlock &BB, ConvergenceControlInst *Parent)
static LLVM_ABI ConvergenceControlInst * CreateEntry(BasicBlock &BB)
static LLVM_ABI DIArgList * get(LLVMContext &Context, ArrayRef< ValueAsMetadata * > Args)
DWARF expression.
LLVM_ABI std::optional< uint64_t > getSizeInBits() const
Determines the size of the variable's type.
LLVM_ABI void setValue(Value *V)
LLVM_ABI void setAssignId(DIAssignID *New)
LLVM_ABI void setKillAddress()
Kill the address component.
LLVM_ABI bool isKillAddress() const
Check whether this kills the address component.
Metadata * getRawAddress() const
LLVM_ABI Value * getAddress() const
LLVM_ABI void setAddress(Value *V)
LLVM_ABI iterator_range< location_op_iterator > location_ops() const
Get the locations corresponding to the variable referenced by the debug info intrinsic.
LLVM_ABI void addVariableLocationOps(ArrayRef< Value * > NewValues, DIExpression *NewExpr)
Adding a new location operand will always result in this intrinsic using an ArgList,...
LLVM_ABI void replaceVariableLocationOp(Value *OldValue, Value *NewValue, bool AllowEmpty=false)
LLVM_ABI Value * getVariableLocationOp(unsigned OpIdx) const
DILocalVariable * getVariable() const
unsigned getNumVariableLocationOps() const
void setOperand(unsigned i, Value *v)
LLVM_ABI std::optional< uint64_t > getFragmentSizeInBits() const
Get the size (in bits) of the variable, or fragment of the variable that is described.
DIExpression * getExpression() const
void setArgOperand(unsigned i, Value *v)
RawLocationWrapper getWrappedLocation() const
LLVM_ABI const Value * getStatepoint() const
The statepoint with which this gc.relocate is associated.
LLVM_ABI Value * getBasePtr() const
unsigned getBasePtrIndex() const
The index into the associate statepoint's argument list which contains the base pointer of the pointe...
LLVM_ABI Value * getDerivedPtr() const
unsigned getDerivedPtrIndex() const
The index into the associate statepoint's argument list which contains the pointer whose relocation t...
LLVM_ABI void setCallee(Value *Callee)
LLVM_ABI Value * getCallee() const
LLVM_ABI ConstantInt * getIndex() const
LLVM_ABI void setIndex(uint32_t Idx)
LLVM_ABI ConstantInt * getNumCounters() const
static bool classof(const IntrinsicInst *I)
LLVM_ABI Value * getStep() const
static bool classof(const IntrinsicInst *I)
bool isCast() const
LLVM_ABI const Module * getModule() const
Return the module owning the function this instruction belongs to or nullptr it the function does not...
static LLVM_ABI bool mayLowerToFunctionCall(Intrinsic::ID IID)
Check if the intrinsic might lower into a regular function call in the course of IR transformations.
Intrinsic::ID getIntrinsicID() const
Return the intrinsic ID of this intrinsic.
This is an important class for using LLVM in a threaded context.
Definition LLVMContext.h:68
static LLVM_ABI MetadataAsValue * get(LLVMContext &Context, Metadata *MD)
Definition Metadata.cpp:110
Root of the metadata hierarchy.
Definition Metadata.h:64
A Module instance is used to store all the information related to an LLVM module.
Definition Module.h:67
static LLVM_ABI PoisonValue * get(Type *T)
Static factory methods - Return an 'poison' object of the specified type.
Metadata * getRawLocation() const
LLVM_ABI iterator_range< location_op_iterator > location_ops() const
Get the locations corresponding to the variable referenced by the debug info intrinsic.
LLVM_ABI Value * getVariableLocationOp(unsigned OpIdx) const
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
A switch()-like statement whose cases are string literals.
StringSwitch & Case(StringLiteral S, T Value)
The instances of the Type class are immutable: once they are created, they are never changed.
Definition Type.h:46
static LLVM_ABI IntegerType * getInt64Ty(LLVMContext &C)
Definition Type.cpp:314
static LLVM_ABI IntegerType * getInt32Ty(LLVMContext &C)
Definition Type.cpp:313
static LLVM_ABI UndefValue * get(Type *T)
Static factory methods - Return an 'undef' object of the specified type.
unsigned getNumOperands() const
Definition User.h:229
static LLVM_ABI bool isVPBinOp(Intrinsic::ID ID)
static LLVM_ABI bool isVPCast(Intrinsic::ID ID)
static LLVM_ABI bool isVPCmp(Intrinsic::ID ID)
LLVM_ABI CmpInst::Predicate getPredicate() const
static LLVM_ABI std::optional< unsigned > getMaskParamPos(Intrinsic::ID IntrinsicID)
LLVM_ABI bool canIgnoreVectorLengthParam() const
LLVM_ABI void setMaskParam(Value *)
static LLVM_ABI std::optional< unsigned > getFunctionalOpcodeForVP(Intrinsic::ID ID)
static LLVM_ABI std::optional< unsigned > getMemoryDataParamPos(Intrinsic::ID)
LLVM_ABI Value * getVectorLengthParam() const
static LLVM_ABI std::optional< Intrinsic::ID > getFunctionalIntrinsicIDForVP(Intrinsic::ID ID)
LLVM_ABI void setVectorLengthParam(Value *)
static LLVM_ABI std::optional< unsigned > getVectorLengthParamPos(Intrinsic::ID IntrinsicID)
static LLVM_ABI Intrinsic::ID getForOpcode(unsigned OC)
The llvm.vp.* intrinsics for this instruction Opcode.
static LLVM_ABI Function * getOrInsertDeclarationForParams(Module *M, Intrinsic::ID, Type *ReturnType, ArrayRef< Value * > Params)
Declares a llvm.vp.
static LLVM_ABI std::optional< unsigned > getMemoryPointerParamPos(Intrinsic::ID)
static LLVM_ABI bool isVPIntrinsic(Intrinsic::ID)
LLVM_ABI Value * getMemoryDataParam() const
static LLVM_ABI Intrinsic::ID getForIntrinsic(Intrinsic::ID Id)
The llvm.vp.
LLVM_ABI Value * getMemoryPointerParam() const
LLVM_ABI MaybeAlign getPointerAlignment() const
LLVM_ABI Value * getMaskParam() const
LLVM_ABI ElementCount getStaticVectorLength() const
static LLVM_ABI std::optional< Intrinsic::ID > getConstrainedIntrinsicIDForVP(Intrinsic::ID ID)
static LLVM_ABI bool isVPReduction(Intrinsic::ID ID)
LLVM_ABI unsigned getStartParamPos() const
LLVM_ABI unsigned getVectorParamPos() const
Value wrapper in the Metadata hierarchy.
Definition Metadata.h:459
static LLVM_ABI ValueAsMetadata * get(Value *V)
Definition Metadata.cpp:509
LLVM Value Representation.
Definition Value.h:75
Type * getType() const
All values are typed, get the type of this value.
Definition Value.h:255
LLVMContext & getContext() const
All values hold a context through their type.
Definition Value.h:258
A range adaptor for a pair of iterators.
CallInst * Call
#define llvm_unreachable(msg)
Marks that the current location is not supposed to be reachable.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
Definition CallingConv.h:24
LLVM_ABI bool hasConstrainedFPRoundingModeOperand(ID QID)
Returns true if the intrinsic ID is for one of the "ConstrainedFloating-Point Intrinsics" that take r...
LLVM_ABI Function * getOrInsertDeclaration(Module *M, ID id, ArrayRef< Type * > OverloadTys={})
Look up the Function declaration of the intrinsic id in the Module M.
LLVM_ABI bool isConstrainedFPIntrinsic(ID QID)
Returns true if the intrinsic ID is for one of the "ConstrainedFloating-Point Intrinsics".
bool match(Val *V, const Pattern &P)
IntrinsicID_match m_VScale()
Matches a call to llvm.vscale().
BinaryOp_match< LHS, RHS, Instruction::Mul > m_Mul(const LHS &L, const RHS &R)
auto m_ConstantInt()
Match an arbitrary ConstantInt and ignore it.
@ ebIgnore
This corresponds to "fpexcept.ignore".
Definition FPEnv.h:40
This is an optimization pass for GlobalISel generic memory operations.
auto find(R &&Range, const T &Val)
Provide wrappers to std::find which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1764
decltype(auto) dyn_cast(const From &Val)
dyn_cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:643
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...
Definition Casting.h:547
OperandBundleDefT< Value * > OperandBundleDef
Definition AutoUpgrade.h:34
LLVM_ABI std::optional< fp::ExceptionBehavior > convertStrToExceptionBehavior(StringRef)
Returns a valid ExceptionBehavior enumerator when given a string valid as input in constrained intrin...
Definition FPEnv.cpp:59
DWARFExpression::Operation Op
@ NearestTiesToEven
roundTiesToEven.
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:559
LLVM_ABI std::optional< RoundingMode > convertStrToRoundingMode(StringRef)
Returns a valid RoundingMode enumerator when given a string that is valid as input in constrained int...
Definition FPEnv.cpp:25
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
Definition STLExtras.h:1946
This struct is a compact representation of a valid (power of two) or undefined (0) alignment.
Definition Alignment.h:106