LLVM 23.0.0git
Instruction.cpp
Go to the documentation of this file.
1//===-- Instruction.cpp - Implement the Instruction class -----------------===//
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 the Instruction class for the IR library.
10//
11//===----------------------------------------------------------------------===//
12
13#include "llvm/IR/Instruction.h"
14#include "llvm/ADT/DenseSet.h"
15#include "llvm/ADT/STLExtras.h"
17#include "llvm/IR/Attributes.h"
18#include "llvm/IR/Constants.h"
19#include "llvm/IR/InstrTypes.h"
22#include "llvm/IR/Intrinsics.h"
23#include "llvm/IR/LLVMContext.h"
25#include "llvm/IR/Module.h"
26#include "llvm/IR/Operator.h"
28#include "llvm/IR/Type.h"
31using namespace llvm;
32
33namespace llvm {
34
35// FIXME: Flag used for an ablation performance test, Issue #147390. Placing it
36// here because referencing IR should be feasible from anywhere. Will be
37// removed after the ablation test.
39 "profcheck-disable-metadata-fixes", cl::Hidden, cl::init(false),
41 "Disable metadata propagation fixes discovered through Issue #147390"));
42
43} // end namespace llvm
44
46 : InsertAt(InsertBefore ? InsertBefore->getIterator()
47 : InstListType::iterator()) {}
49 : InsertAt(InsertAtEnd ? InsertAtEnd->end() : InstListType::iterator()) {}
50
51Instruction::Instruction(Type *ty, unsigned it, AllocInfo AllocInfo,
52 InsertPosition InsertBefore)
53 : User(ty, Value::InstructionVal + it, AllocInfo) {
54 // When called with an iterator, there must be a block to insert into.
55 if (InstListType::iterator InsertIt = InsertBefore; InsertIt.isValid()) {
56 BasicBlock *BB = InsertIt.getNodeParent();
57 assert(BB && "Instruction to insert before is not in a basic block!");
58 insertInto(BB, InsertBefore);
59 }
60}
61
63 assert(!getParent() && "Instruction still linked in the program!");
64
65 // Replace any extant metadata uses of this instruction with poison to
66 // preserve debug info accuracy. Some alternatives include:
67 // - Treat Instruction like any other Value, and point its extant metadata
68 // uses to an empty ValueAsMetadata node. This makes extant dbg.value uses
69 // trivially dead (i.e. fair game for deletion in many passes), leading to
70 // stale dbg.values being in effect for too long.
71 // - Call salvageDebugInfoOrMarkUndef. Not needed to make instruction removal
72 // correct. OTOH results in wasted work in some common cases (e.g. when all
73 // instructions in a BasicBlock are deleted).
74 if (isUsedByMetadata())
76
77 // Remove associated metadata from context.
78 if (hasMetadata()) {
79 // Explicitly remove DIAssignID metadata to clear up ID -> Instruction(s)
80 // mapping in LLVMContext.
81 updateDIAssignIDMapping(nullptr);
82 clearMetadata();
83 }
84}
85
86const Module *Instruction::getModule() const {
87 return getParent()->getModule();
88}
89
91 return getParent()->getParent();
92}
93
95 return getModule()->getDataLayout();
96}
97
99 // Perform any debug-info maintenence required.
100 handleMarkerRemoval();
101
102 getParent()->getInstList().remove(getIterator());
103}
104
106 if (!DebugMarker)
107 return;
108
109 DebugMarker->removeMarker();
110}
111
113 handleMarkerRemoval();
114 return getParent()->getInstList().erase(getIterator());
115}
116
117void Instruction::insertBefore(Instruction *InsertPos) {
118 insertBefore(InsertPos->getIterator());
119}
120
121/// Insert an unlinked instruction into a basic block immediately before the
122/// specified instruction.
124 insertBefore(*InsertPos->getParent(), InsertPos);
125}
126
127/// Insert an unlinked instruction into a basic block immediately after the
128/// specified instruction.
129void Instruction::insertAfter(Instruction *InsertPos) {
130 BasicBlock *DestParent = InsertPos->getParent();
131
132 DestParent->getInstList().insertAfter(InsertPos->getIterator(), this);
133}
134
136 BasicBlock *DestParent = InsertPos->getParent();
137
138 DestParent->getInstList().insertAfter(InsertPos, this);
139}
140
143 assert(getParent() == nullptr && "Expected detached instruction");
144 assert((It == ParentBB->end() || It->getParent() == ParentBB) &&
145 "It not in ParentBB");
146 insertBefore(*ParentBB, It);
147 return getIterator();
148}
149
151 InstListType::iterator InsertPos) {
152 assert(!DebugMarker);
153
154 BB.getInstList().insert(InsertPos, this);
155
156 // We've inserted "this": if InsertAtHead is set then it comes before any
157 // DbgVariableRecords attached to InsertPos. But if it's not set, then any
158 // DbgRecords should now come before "this".
159 bool InsertAtHead = InsertPos.getHeadBit();
160 if (!InsertAtHead) {
161 DbgMarker *SrcMarker = BB.getMarker(InsertPos);
162 if (SrcMarker && !SrcMarker->empty()) {
163 // If this assertion fires, the calling code is about to insert a PHI
164 // after debug-records, which would form a sequence like:
165 // %0 = PHI
166 // #dbg_value
167 // %1 = PHI
168 // Which is de-normalised and undesired -- hence the assertion. To avoid
169 // this, you must insert at that position using an iterator, and it must
170 // be aquired by calling getFirstNonPHIIt / begin or similar methods on
171 // the block. This will signal to this behind-the-scenes debug-info
172 // maintenence code that you intend the PHI to be ahead of everything,
173 // including any debug-info.
174 assert(!isa<PHINode>(this) && "Inserting PHI after debug-records!");
175 adoptDbgRecords(&BB, InsertPos, false);
176 }
177 }
178
179 // If we're inserting a terminator, check if we need to flush out
180 // TrailingDbgRecords. Inserting instructions at the end of an incomplete
181 // block is handled by the code block above.
182 if (isTerminator())
183 getParent()->flushTerminatorDbgRecords();
184}
185
186/// Unlink this instruction from its current basic block and insert it into the
187/// basic block that MovePos lives in, right before MovePos.
189 moveBeforeImpl(*MovePos->getParent(), MovePos->getIterator(), false);
190}
191
193 moveBeforeImpl(*MovePos->getParent(), MovePos, false);
194}
195
197 moveBeforeImpl(*MovePos->getParent(), MovePos->getIterator(), true);
198}
199
201 moveBeforeImpl(*MovePos->getParent(), MovePos, true);
202}
203
204void Instruction::moveAfter(Instruction *MovePos) {
205 auto NextIt = std::next(MovePos->getIterator());
206 // We want this instruction to be moved to after NextIt in the instruction
207 // list, but before NextIt's debug value range.
208 NextIt.setHeadBit(true);
209 moveBeforeImpl(*MovePos->getParent(), NextIt, false);
210}
211
212void Instruction::moveAfter(InstListType::iterator MovePos) {
213 // We want this instruction to be moved to after NextIt in the instruction
214 // list, but before NextIt's debug value range.
215 MovePos.setHeadBit(true);
216 moveBeforeImpl(*MovePos->getParent(), MovePos, false);
217}
218
220 auto NextIt = std::next(MovePos->getIterator());
221 // We want this instruction and its debug range to be moved to after NextIt
222 // in the instruction list, but before NextIt's debug value range.
223 NextIt.setHeadBit(true);
224 moveBeforeImpl(*MovePos->getParent(), NextIt, true);
225}
226
227void Instruction::moveBefore(BasicBlock &BB, InstListType::iterator I) {
228 moveBeforeImpl(BB, I, false);
229}
230
232 InstListType::iterator I) {
233 moveBeforeImpl(BB, I, true);
234}
235
236void Instruction::moveBeforeImpl(BasicBlock &BB, InstListType::iterator I,
237 bool Preserve) {
238 assert(I == BB.end() || I->getParent() == &BB);
239 bool InsertAtHead = I.getHeadBit();
240
241 // If we've been given the "Preserve" flag, then just move the DbgRecords with
242 // the instruction, no more special handling needed.
243 if (DebugMarker && !Preserve) {
244 if (I != this->getIterator() || InsertAtHead) {
245 // "this" is definitely moving in the list, or it's moving ahead of its
246 // attached DbgVariableRecords. Detach any existing DbgRecords.
247 handleMarkerRemoval();
248 }
249 }
250
251 // Move this single instruction. Use the list splice method directly, not
252 // the block splicer, which will do more debug-info things.
253 BB.getInstList().splice(I, getParent()->getInstList(), getIterator());
254
255 if (!Preserve) {
256 DbgMarker *NextMarker = getParent()->getNextMarker(this);
257
258 // If we're inserting at point I, and not in front of the DbgRecords
259 // attached there, then we should absorb the DbgRecords attached to I.
260 if (!InsertAtHead && NextMarker && !NextMarker->empty()) {
261 adoptDbgRecords(&BB, I, false);
262 }
263 }
264
265 if (isTerminator())
266 getParent()->flushTerminatorDbgRecords();
267}
268
270 const Instruction *From, std::optional<DbgRecord::self_iterator> FromHere,
271 bool InsertAtHead) {
272 if (!From->DebugMarker)
274
275 if (!DebugMarker)
276 getParent()->createMarker(this);
277
278 return DebugMarker->cloneDebugInfoFrom(From->DebugMarker, FromHere,
279 InsertAtHead);
280}
281
282std::optional<DbgRecord::self_iterator>
284 // Is there a marker on the next instruction?
285 DbgMarker *NextMarker = getParent()->getNextMarker(this);
286 if (!NextMarker)
287 return std::nullopt;
288
289 // Are there any DbgRecords in the next marker?
290 if (NextMarker->StoredDbgRecords.empty())
291 return std::nullopt;
292
293 return NextMarker->StoredDbgRecords.begin();
294}
295
296bool Instruction::hasDbgRecords() const { return !getDbgRecordRange().empty(); }
297
299 bool InsertAtHead) {
300 DbgMarker *SrcMarker = BB->getMarker(It);
301 auto ReleaseTrailingDbgRecords = [BB, It, SrcMarker]() {
302 if (BB->end() == It) {
303 SrcMarker->eraseFromParent();
305 }
306 };
307
308 if (!SrcMarker || SrcMarker->StoredDbgRecords.empty()) {
309 ReleaseTrailingDbgRecords();
310 return;
311 }
312
313 // If we have DbgMarkers attached to this instruction, we have to honour the
314 // ordering of DbgRecords between this and the other marker. Fall back to just
315 // absorbing from the source.
316 if (DebugMarker || It == BB->end()) {
317 // Ensure we _do_ have a marker.
318 getParent()->createMarker(this);
319 DebugMarker->absorbDebugValues(*SrcMarker, InsertAtHead);
320
321 // Having transferred everything out of SrcMarker, we _could_ clean it up
322 // and free the marker now. However, that's a lot of heap-accounting for a
323 // small amount of memory with a good chance of re-use. Leave it for the
324 // moment. It will be released when the Instruction is freed in the worst
325 // case.
326 // However: if we transferred from a trailing marker off the end of the
327 // block, it's important to not leave the empty marker trailing. It will
328 // give a misleading impression that some debug records have been left
329 // trailing.
330 ReleaseTrailingDbgRecords();
331 } else {
332 // Optimisation: we're transferring all the DbgRecords from the source
333 // marker onto this empty location: just adopt the other instructions
334 // marker.
335 DebugMarker = SrcMarker;
336 DebugMarker->MarkedInstr = this;
337 It->DebugMarker = nullptr;
338 }
339}
340
342 if (DebugMarker)
343 DebugMarker->dropDbgRecords();
344}
345
347 DebugMarker->dropOneDbgRecord(DVR);
348}
349
350bool Instruction::comesBefore(const Instruction *Other) const {
351 assert(getParent() && Other->getParent() &&
352 "instructions without BB parents have no order");
353 assert(getParent() == Other->getParent() &&
354 "cross-BB instruction order comparison");
355 if (!getParent()->isInstrOrderValid())
356 const_cast<BasicBlock *>(getParent())->renumberInstructions();
357 return Order < Other->Order;
358}
359
360std::optional<BasicBlock::iterator> Instruction::getInsertionPointAfterDef() {
361 assert(!getType()->isVoidTy() && "Instruction must define result");
362 BasicBlock *InsertBB;
363 BasicBlock::iterator InsertPt;
364 if (auto *PN = dyn_cast<PHINode>(this)) {
365 InsertBB = PN->getParent();
366 InsertPt = InsertBB->getFirstInsertionPt();
367 } else if (auto *II = dyn_cast<InvokeInst>(this)) {
368 InsertBB = II->getNormalDest();
369 InsertPt = InsertBB->getFirstInsertionPt();
370 } else if (isa<CallBrInst>(this)) {
371 // Def is available in multiple successors, there's no single dominating
372 // insertion point.
373 return std::nullopt;
374 } else {
375 assert(!isTerminator() && "Only invoke/callbr terminators return value");
376 InsertBB = getParent();
377 InsertPt = std::next(getIterator());
378 // Any instruction inserted immediately after "this" will come before any
379 // debug-info records take effect -- thus, set the head bit indicating that
380 // to debug-info-transfer code.
381 InsertPt.setHeadBit(true);
382 }
383
384 // catchswitch blocks don't have any legal insertion point (because they
385 // are both an exception pad and a terminator).
386 if (InsertPt == InsertBB->end())
387 return std::nullopt;
388 return InsertPt;
389}
390
392 return any_of(operands(), [](const Value *V) { return V->hasOneUser(); });
393}
394
396 if (auto *Inst = dyn_cast<OverflowingBinaryOperator>(this))
397 Inst->setHasNoUnsignedWrap(b);
398 else
399 cast<TruncInst>(this)->setHasNoUnsignedWrap(b);
400}
401
403 if (auto *Inst = dyn_cast<OverflowingBinaryOperator>(this))
404 Inst->setHasNoSignedWrap(b);
405 else
406 cast<TruncInst>(this)->setHasNoSignedWrap(b);
407}
408
409void Instruction::setIsExact(bool b) {
410 cast<PossiblyExactOperator>(this)->setIsExact(b);
411}
412
413void Instruction::setNonNeg(bool b) {
414 assert(isa<PossiblyNonNegInst>(this) && "Must be zext/uitofp");
415 SubclassOptionalData = (SubclassOptionalData & ~PossiblyNonNegInst::NonNeg) |
417}
418
420 if (auto *Inst = dyn_cast<OverflowingBinaryOperator>(this))
421 return Inst->hasNoUnsignedWrap();
422
423 return cast<TruncInst>(this)->hasNoUnsignedWrap();
424}
425
426bool Instruction::hasNoSignedWrap() const {
427 if (auto *Inst = dyn_cast<OverflowingBinaryOperator>(this))
428 return Inst->hasNoSignedWrap();
429
430 return cast<TruncInst>(this)->hasNoSignedWrap();
431}
432
433bool Instruction::hasNonNeg() const {
434 assert(isa<PossiblyNonNegInst>(this) && "Must be zext/uitofp");
435 return (SubclassOptionalData & PossiblyNonNegInst::NonNeg) != 0;
436}
437
439 return cast<Operator>(this)->hasPoisonGeneratingFlags();
440}
441
443 switch (getOpcode()) {
444 case Instruction::Add:
445 case Instruction::Sub:
446 case Instruction::Mul:
447 case Instruction::Shl:
448 cast<OverflowingBinaryOperator>(this)->setHasNoUnsignedWrap(false);
449 cast<OverflowingBinaryOperator>(this)->setHasNoSignedWrap(false);
450 break;
451
452 case Instruction::UDiv:
453 case Instruction::SDiv:
454 case Instruction::AShr:
455 case Instruction::LShr:
456 cast<PossiblyExactOperator>(this)->setIsExact(false);
457 break;
458
459 case Instruction::Or:
460 cast<PossiblyDisjointInst>(this)->setIsDisjoint(false);
461 break;
462
463 case Instruction::GetElementPtr:
464 cast<GetElementPtrInst>(this)->setNoWrapFlags(GEPNoWrapFlags::none());
465 break;
466
467 case Instruction::UIToFP:
468 case Instruction::ZExt:
469 setNonNeg(false);
470 break;
471
472 case Instruction::Trunc:
473 cast<TruncInst>(this)->setHasNoUnsignedWrap(false);
474 cast<TruncInst>(this)->setHasNoSignedWrap(false);
475 break;
476
477 case Instruction::ICmp:
478 cast<ICmpInst>(this)->setSameSign(false);
479 break;
480
481 case Instruction::Call: {
482 if (auto *II = dyn_cast<IntrinsicInst>(this)) {
483 switch (II->getIntrinsicID()) {
484 case Intrinsic::ctlz:
485 case Intrinsic::cttz:
486 case Intrinsic::abs:
487 II->setOperand(1, ConstantInt::getFalse(getContext()));
488 break;
489 }
490 }
491 break;
492 }
493 }
494
495 if (isa<FPMathOperator>(this)) {
496 setHasNoNaNs(false);
497 setHasNoInfs(false);
498 }
499
500 assert(!hasPoisonGeneratingFlags() && "must be kept in sync");
501}
502
505 [this](unsigned ID) { return hasMetadata(ID); });
506}
507
509 // If there is no loop metadata at all, we also don't have
510 // non-debug loop metadata, obviously.
511 if (!hasMetadata(LLVMContext::MD_loop))
512 return false;
513
514 // If we do have loop metadata, retrieve it.
515 MDNode *LoopMD = getMetadata(LLVMContext::MD_loop);
516
517 // Check if the existing operands are debug locations. This loop
518 // should terminate after at most three iterations. Skip
519 // the first item because it is a self-reference.
520 for (const MDOperand &Op : llvm::drop_begin(LoopMD->operands())) {
521 // check for debug location type by attempting a cast.
522 if (!isa<DILocation>(Op)) {
523 return true;
524 }
525 }
526
527 // If we get here, then all we have is debug locations in the loop metadata.
528 return false;
529}
530
532 for (unsigned ID : Metadata::PoisonGeneratingIDs)
533 eraseMetadata(ID);
534}
535
537 if (const auto *CB = dyn_cast<CallBase>(this)) {
538 auto HasPoisonGeneratingAttributes = [](AttributeSet Attrs) {
539 return Attrs.hasAttribute(Attribute::Range) ||
540 Attrs.hasAttribute(Attribute::Alignment) ||
541 Attrs.hasAttribute(Attribute::NonNull) ||
542 Attrs.hasAttribute(Attribute::NoFPClass);
543 };
544 if (HasPoisonGeneratingAttributes(CB->getRetAttributes()))
545 return true;
546 for (unsigned ArgNo = 0; ArgNo < CB->arg_size(); ArgNo++)
547 if (HasPoisonGeneratingAttributes(CB->getParamAttributes(ArgNo)))
548 return true;
549 }
550 return false;
551}
552
554 if (auto *CB = dyn_cast<CallBase>(this)) {
555 AttributeMask AM;
556 AM.addAttribute(Attribute::Range);
557 AM.addAttribute(Attribute::Alignment);
558 AM.addAttribute(Attribute::NonNull);
559 AM.addAttribute(Attribute::NoFPClass);
560 CB->removeRetAttrs(AM);
561 for (unsigned ArgNo = 0; ArgNo < CB->arg_size(); ArgNo++)
562 CB->removeParamAttrs(ArgNo, AM);
563 }
564 assert(!hasPoisonGeneratingAttributes() && "must be kept in sync");
565}
566
568 ArrayRef<unsigned> KnownIDs) {
569 dropUnknownNonDebugMetadata(KnownIDs);
570 auto *CB = dyn_cast<CallBase>(this);
571 if (!CB)
572 return;
573 // For call instructions, we also need to drop parameter and return attributes
574 // that can cause UB if the call is moved to a location where the attribute is
575 // not valid.
576 AttributeList AL = CB->getAttributes();
577 if (AL.isEmpty())
578 return;
579 AttributeMask UBImplyingAttributes =
580 AttributeFuncs::getUBImplyingAttributes();
581 for (unsigned ArgNo = 0; ArgNo < CB->arg_size(); ArgNo++)
582 CB->removeParamAttrs(ArgNo, UBImplyingAttributes);
583 CB->removeRetAttrs(UBImplyingAttributes);
584}
585
587 // !annotation and !prof metadata does not impact semantics.
588 // !range, !nonnull and !align produce poison, so they are safe to speculate.
589 // !fpmath specifies floating-point precision and does not imply UB.
590 // !mem.cache_hint is a performance hint and does not imply UB.
591 // !noundef and various AA metadata must be dropped, as it generally produces
592 // immediate undefined behavior.
593 static const unsigned KnownIDs[] = {
594 LLVMContext::MD_annotation, LLVMContext::MD_range,
595 LLVMContext::MD_nonnull, LLVMContext::MD_align,
596 LLVMContext::MD_fpmath, LLVMContext::MD_prof,
597 LLVMContext::MD_mem_cache_hint};
598 SmallVector<unsigned> KeepIDs;
599 KeepIDs.reserve(Keep.size() + std::size(KnownIDs));
600 append_range(KeepIDs, (!ProfcheckDisableMetadataFixes ? KnownIDs
601 : drop_end(KnownIDs)));
602 append_range(KeepIDs, Keep);
603 dropUBImplyingAttrsAndUnknownMetadata(KeepIDs);
604}
605
607 auto *CB = dyn_cast<CallBase>(this);
608 if (!CB)
609 return false;
610 // For call instructions, we also need to check parameter and return
611 // attributes that can cause UB.
612 for (unsigned ArgNo = 0; ArgNo < CB->arg_size(); ArgNo++)
613 if (CB->isPassingUndefUB(ArgNo))
614 return true;
615 return CB->hasRetAttr(Attribute::NoUndef) ||
616 CB->hasRetAttr(Attribute::Dereferenceable) ||
617 CB->hasRetAttr(Attribute::DereferenceableOrNull);
618}
619
620bool Instruction::isExact() const {
621 return cast<PossiblyExactOperator>(this)->isExact();
622}
623
624void Instruction::setFast(bool B) {
625 assert(isa<FPMathOperator>(this) && "setting fast-math flag on invalid op");
626 cast<FPMathOperator>(this)->setFast(B);
627}
628
630 assert(isa<FPMathOperator>(this) && "setting fast-math flag on invalid op");
631 cast<FPMathOperator>(this)->setHasAllowReassoc(B);
632}
633
634void Instruction::setHasNoNaNs(bool B) {
635 assert(isa<FPMathOperator>(this) && "setting fast-math flag on invalid op");
636 cast<FPMathOperator>(this)->setHasNoNaNs(B);
637}
638
639void Instruction::setHasNoInfs(bool B) {
640 assert(isa<FPMathOperator>(this) && "setting fast-math flag on invalid op");
641 cast<FPMathOperator>(this)->setHasNoInfs(B);
642}
643
645 assert(isa<FPMathOperator>(this) && "setting fast-math flag on invalid op");
646 cast<FPMathOperator>(this)->setHasNoSignedZeros(B);
647}
648
650 assert(isa<FPMathOperator>(this) && "setting fast-math flag on invalid op");
651 cast<FPMathOperator>(this)->setHasAllowReciprocal(B);
652}
653
655 assert(isa<FPMathOperator>(this) && "setting fast-math flag on invalid op");
656 cast<FPMathOperator>(this)->setHasAllowContract(B);
657}
658
660 assert(isa<FPMathOperator>(this) && "setting fast-math flag on invalid op");
661 cast<FPMathOperator>(this)->setHasApproxFunc(B);
662}
663
665 assert(isa<FPMathOperator>(this) && "setting fast-math flag on invalid op");
666 cast<FPMathOperator>(this)->setFastMathFlags(FMF);
667}
668
670 assert(isa<FPMathOperator>(this) && "copying fast-math flag on invalid op");
671 cast<FPMathOperator>(this)->copyFastMathFlags(FMF);
672}
673
674bool Instruction::isFast() const {
675 assert(isa<FPMathOperator>(this) && "getting fast-math flag on invalid op");
676 return cast<FPMathOperator>(this)->isFast();
677}
678
679bool Instruction::hasAllowReassoc() const {
680 assert(isa<FPMathOperator>(this) && "getting fast-math flag on invalid op");
681 return cast<FPMathOperator>(this)->hasAllowReassoc();
682}
683
684bool Instruction::hasNoNaNs() const {
685 assert(isa<FPMathOperator>(this) && "getting fast-math flag on invalid op");
686 return cast<FPMathOperator>(this)->hasNoNaNs();
687}
688
689bool Instruction::hasNoInfs() const {
690 assert(isa<FPMathOperator>(this) && "getting fast-math flag on invalid op");
691 return cast<FPMathOperator>(this)->hasNoInfs();
692}
693
695 assert(isa<FPMathOperator>(this) && "getting fast-math flag on invalid op");
696 return cast<FPMathOperator>(this)->hasNoSignedZeros();
697}
698
700 assert(isa<FPMathOperator>(this) && "getting fast-math flag on invalid op");
701 return cast<FPMathOperator>(this)->hasAllowReciprocal();
702}
703
705 assert(isa<FPMathOperator>(this) && "getting fast-math flag on invalid op");
706 return cast<FPMathOperator>(this)->hasAllowContract();
707}
708
709bool Instruction::hasApproxFunc() const {
710 assert(isa<FPMathOperator>(this) && "getting fast-math flag on invalid op");
711 return cast<FPMathOperator>(this)->hasApproxFunc();
712}
713
715 assert(isa<FPMathOperator>(this) && "getting fast-math flag on invalid op");
716 return cast<FPMathOperator>(this)->getFastMathFlags();
717}
718
720 if (!isa<FPMathOperator>(this))
721 return {};
722 return cast<FPMathOperator>(this)->getFastMathFlags();
723}
724
726 copyFastMathFlags(I->getFastMathFlags());
727}
728
729void Instruction::copyIRFlags(const Value *V, bool IncludeWrapFlags) {
730 // Copy the wrapping flags.
731 if (IncludeWrapFlags && isa<OverflowingBinaryOperator>(this)) {
732 if (auto *OB = dyn_cast<OverflowingBinaryOperator>(V)) {
733 setHasNoSignedWrap(OB->hasNoSignedWrap());
734 setHasNoUnsignedWrap(OB->hasNoUnsignedWrap());
735 }
736 }
737
738 if (auto *TI = dyn_cast<TruncInst>(V)) {
739 if (isa<TruncInst>(this)) {
740 setHasNoSignedWrap(TI->hasNoSignedWrap());
741 setHasNoUnsignedWrap(TI->hasNoUnsignedWrap());
742 }
743 }
744
745 // Copy the exact flag.
746 if (auto *PE = dyn_cast<PossiblyExactOperator>(V))
748 setIsExact(PE->isExact());
749
750 if (auto *SrcPD = dyn_cast<PossiblyDisjointInst>(V))
751 if (auto *DestPD = dyn_cast<PossiblyDisjointInst>(this))
752 DestPD->setIsDisjoint(SrcPD->isDisjoint());
753
754 // Copy the fast-math flags.
755 if (auto *FP = dyn_cast<FPMathOperator>(V))
756 if (isa<FPMathOperator>(this))
757 copyFastMathFlags(FP->getFastMathFlags());
758
759 if (auto *SrcGEP = dyn_cast<GetElementPtrInst>(V))
760 if (auto *DestGEP = dyn_cast<GetElementPtrInst>(this))
761 DestGEP->setNoWrapFlags(SrcGEP->getNoWrapFlags() |
762 DestGEP->getNoWrapFlags());
763
764 if (auto *NNI = dyn_cast<PossiblyNonNegInst>(V))
765 if (isa<PossiblyNonNegInst>(this))
766 setNonNeg(NNI->hasNonNeg());
767
768 if (auto *SrcICmp = dyn_cast<ICmpInst>(V))
769 if (auto *DestICmp = dyn_cast<ICmpInst>(this))
770 DestICmp->setSameSign(SrcICmp->hasSameSign());
771}
772
773void Instruction::andIRFlags(const Value *V) {
774 if (auto *OB = dyn_cast<OverflowingBinaryOperator>(V)) {
776 setHasNoSignedWrap(hasNoSignedWrap() && OB->hasNoSignedWrap());
777 setHasNoUnsignedWrap(hasNoUnsignedWrap() && OB->hasNoUnsignedWrap());
778 }
779 }
780
781 if (auto *TI = dyn_cast<TruncInst>(V)) {
782 if (isa<TruncInst>(this)) {
783 setHasNoSignedWrap(hasNoSignedWrap() && TI->hasNoSignedWrap());
784 setHasNoUnsignedWrap(hasNoUnsignedWrap() && TI->hasNoUnsignedWrap());
785 }
786 }
787
788 if (auto *PE = dyn_cast<PossiblyExactOperator>(V))
790 setIsExact(isExact() && PE->isExact());
791
792 if (auto *SrcPD = dyn_cast<PossiblyDisjointInst>(V))
793 if (auto *DestPD = dyn_cast<PossiblyDisjointInst>(this))
794 DestPD->setIsDisjoint(DestPD->isDisjoint() && SrcPD->isDisjoint());
795
796 if (auto *FP = dyn_cast<FPMathOperator>(V)) {
797 if (isa<FPMathOperator>(this)) {
798 FastMathFlags FM = getFastMathFlags();
799 FM &= FP->getFastMathFlags();
800 copyFastMathFlags(FM);
801 }
802 }
803
804 if (auto *SrcGEP = dyn_cast<GetElementPtrInst>(V))
805 if (auto *DestGEP = dyn_cast<GetElementPtrInst>(this))
806 DestGEP->setNoWrapFlags(SrcGEP->getNoWrapFlags() &
807 DestGEP->getNoWrapFlags());
808
809 if (auto *NNI = dyn_cast<PossiblyNonNegInst>(V))
810 if (isa<PossiblyNonNegInst>(this))
811 setNonNeg(hasNonNeg() && NNI->hasNonNeg());
812
813 if (auto *SrcICmp = dyn_cast<ICmpInst>(V))
814 if (auto *DestICmp = dyn_cast<ICmpInst>(this))
815 DestICmp->setSameSign(DestICmp->hasSameSign() && SrcICmp->hasSameSign());
816}
817
818const char *Instruction::getOpcodeName(unsigned OpCode) {
819 switch (OpCode) {
820 // Terminators
821 case Ret: return "ret";
822 case UncondBr: return "br";
823 case CondBr: return "br";
824 case Switch: return "switch";
825 case IndirectBr: return "indirectbr";
826 case Invoke: return "invoke";
827 case Resume: return "resume";
828 case Unreachable: return "unreachable";
829 case CleanupRet: return "cleanupret";
830 case CatchRet: return "catchret";
831 case CatchPad: return "catchpad";
832 case CatchSwitch: return "catchswitch";
833 case CallBr: return "callbr";
834
835 // Standard unary operators...
836 case FNeg: return "fneg";
837
838 // Standard binary operators...
839 case Add: return "add";
840 case FAdd: return "fadd";
841 case Sub: return "sub";
842 case FSub: return "fsub";
843 case Mul: return "mul";
844 case FMul: return "fmul";
845 case UDiv: return "udiv";
846 case SDiv: return "sdiv";
847 case FDiv: return "fdiv";
848 case URem: return "urem";
849 case SRem: return "srem";
850 case FRem: return "frem";
851
852 // Logical operators...
853 case And: return "and";
854 case Or : return "or";
855 case Xor: return "xor";
856
857 // Memory instructions...
858 case Alloca: return "alloca";
859 case Load: return "load";
860 case Store: return "store";
861 case AtomicCmpXchg: return "cmpxchg";
862 case AtomicRMW: return "atomicrmw";
863 case Fence: return "fence";
864 case GetElementPtr: return "getelementptr";
865
866 // Convert instructions...
867 case Trunc: return "trunc";
868 case ZExt: return "zext";
869 case SExt: return "sext";
870 case FPTrunc: return "fptrunc";
871 case FPExt: return "fpext";
872 case FPToUI: return "fptoui";
873 case FPToSI: return "fptosi";
874 case UIToFP: return "uitofp";
875 case SIToFP: return "sitofp";
876 case IntToPtr: return "inttoptr";
877 case PtrToAddr: return "ptrtoaddr";
878 case PtrToInt: return "ptrtoint";
879 case BitCast: return "bitcast";
880 case AddrSpaceCast: return "addrspacecast";
881
882 // Other instructions...
883 case ICmp: return "icmp";
884 case FCmp: return "fcmp";
885 case PHI: return "phi";
886 case Select: return "select";
887 case Call: return "call";
888 case Shl: return "shl";
889 case LShr: return "lshr";
890 case AShr: return "ashr";
891 case VAArg: return "va_arg";
892 case ExtractElement: return "extractelement";
893 case InsertElement: return "insertelement";
894 case ShuffleVector: return "shufflevector";
895 case ExtractValue: return "extractvalue";
896 case InsertValue: return "insertvalue";
897 case LandingPad: return "landingpad";
898 case CleanupPad: return "cleanuppad";
899 case Freeze: return "freeze";
900
901 default: return "<Invalid operator> ";
902 }
903}
904
905/// This must be kept in sync with FunctionComparator::cmpOperations in
906/// lib/Transforms/Utils/FunctionComparator.cpp.
908 bool IgnoreAlignment,
909 bool IntersectAttrs) const {
910 const auto *I1 = this;
911 assert(I1->getOpcode() == I2->getOpcode() &&
912 "Can not compare special state of different instructions");
913
914 auto CheckAttrsSame = [IntersectAttrs](const CallBase *CB0,
915 const CallBase *CB1) {
916 return IntersectAttrs
917 ? CB0->getAttributes()
918 .intersectWith(CB0->getContext(), CB1->getAttributes())
919 .has_value()
920 : CB0->getAttributes() == CB1->getAttributes();
921 };
922
923 if (const AllocaInst *AI = dyn_cast<AllocaInst>(I1))
924 return AI->getAllocatedType() == cast<AllocaInst>(I2)->getAllocatedType() &&
925 (AI->getAlign() == cast<AllocaInst>(I2)->getAlign() ||
926 IgnoreAlignment);
927 if (const LoadInst *LI = dyn_cast<LoadInst>(I1))
928 return LI->isVolatile() == cast<LoadInst>(I2)->isVolatile() &&
929 (LI->getAlign() == cast<LoadInst>(I2)->getAlign() ||
930 IgnoreAlignment) &&
931 LI->getOrdering() == cast<LoadInst>(I2)->getOrdering() &&
932 LI->getSyncScopeID() == cast<LoadInst>(I2)->getSyncScopeID();
933 if (const StoreInst *SI = dyn_cast<StoreInst>(I1))
934 return SI->isVolatile() == cast<StoreInst>(I2)->isVolatile() &&
935 (SI->getAlign() == cast<StoreInst>(I2)->getAlign() ||
936 IgnoreAlignment) &&
937 SI->getOrdering() == cast<StoreInst>(I2)->getOrdering() &&
938 SI->getSyncScopeID() == cast<StoreInst>(I2)->getSyncScopeID();
939 if (const CmpInst *CI = dyn_cast<CmpInst>(I1))
940 return CI->getPredicate() == cast<CmpInst>(I2)->getPredicate();
941 if (const CallInst *CI = dyn_cast<CallInst>(I1))
942 return CI->isTailCall() == cast<CallInst>(I2)->isTailCall() &&
943 CI->getCallingConv() == cast<CallInst>(I2)->getCallingConv() &&
944 CheckAttrsSame(CI, cast<CallInst>(I2)) &&
945 CI->hasIdenticalOperandBundleSchema(*cast<CallInst>(I2));
946 if (const InvokeInst *CI = dyn_cast<InvokeInst>(I1))
947 return CI->getCallingConv() == cast<InvokeInst>(I2)->getCallingConv() &&
948 CheckAttrsSame(CI, cast<InvokeInst>(I2)) &&
949 CI->hasIdenticalOperandBundleSchema(*cast<InvokeInst>(I2));
950 if (const CallBrInst *CI = dyn_cast<CallBrInst>(I1))
951 return CI->getCallingConv() == cast<CallBrInst>(I2)->getCallingConv() &&
952 CheckAttrsSame(CI, cast<CallBrInst>(I2)) &&
953 CI->hasIdenticalOperandBundleSchema(*cast<CallBrInst>(I2));
954 if (const SwitchInst *SI = dyn_cast<SwitchInst>(I1)) {
955 for (auto [Case1, Case2] : zip(SI->cases(), cast<SwitchInst>(I2)->cases()))
956 if (Case1.getCaseValue() != Case2.getCaseValue())
957 return false;
958 return true;
959 }
960 if (const InsertValueInst *IVI = dyn_cast<InsertValueInst>(I1))
961 return IVI->getIndices() == cast<InsertValueInst>(I2)->getIndices();
962 if (const ExtractValueInst *EVI = dyn_cast<ExtractValueInst>(I1))
963 return EVI->getIndices() == cast<ExtractValueInst>(I2)->getIndices();
964 if (const FenceInst *FI = dyn_cast<FenceInst>(I1))
965 return FI->getOrdering() == cast<FenceInst>(I2)->getOrdering() &&
966 FI->getSyncScopeID() == cast<FenceInst>(I2)->getSyncScopeID();
968 return CXI->isVolatile() == cast<AtomicCmpXchgInst>(I2)->isVolatile() &&
969 (CXI->getAlign() == cast<AtomicCmpXchgInst>(I2)->getAlign() ||
970 IgnoreAlignment) &&
971 CXI->isWeak() == cast<AtomicCmpXchgInst>(I2)->isWeak() &&
972 CXI->getSuccessOrdering() ==
973 cast<AtomicCmpXchgInst>(I2)->getSuccessOrdering() &&
974 CXI->getFailureOrdering() ==
975 cast<AtomicCmpXchgInst>(I2)->getFailureOrdering() &&
976 CXI->getSyncScopeID() ==
977 cast<AtomicCmpXchgInst>(I2)->getSyncScopeID();
978 if (const AtomicRMWInst *RMWI = dyn_cast<AtomicRMWInst>(I1))
979 return RMWI->getOperation() == cast<AtomicRMWInst>(I2)->getOperation() &&
980 RMWI->isElementwise() == cast<AtomicRMWInst>(I2)->isElementwise() &&
981 RMWI->isVolatile() == cast<AtomicRMWInst>(I2)->isVolatile() &&
982 (RMWI->getAlign() == cast<AtomicRMWInst>(I2)->getAlign() ||
983 IgnoreAlignment) &&
984 RMWI->getOrdering() == cast<AtomicRMWInst>(I2)->getOrdering() &&
985 RMWI->getSyncScopeID() == cast<AtomicRMWInst>(I2)->getSyncScopeID();
987 return SVI->getShuffleMask() ==
988 cast<ShuffleVectorInst>(I2)->getShuffleMask();
990 return GEP->getSourceElementType() ==
991 cast<GetElementPtrInst>(I2)->getSourceElementType();
992
993 return true;
994}
995
996bool Instruction::isIdenticalTo(const Instruction *I) const {
997 return isIdenticalToWhenDefined(I) &&
998 SubclassOptionalData == I->SubclassOptionalData;
999}
1000
1002 bool IntersectAttrs) const {
1003 if (getOpcode() != I->getOpcode() ||
1004 getNumOperands() != I->getNumOperands() || getType() != I->getType())
1005 return false;
1006
1007 // If both instructions have no operands, they are identical.
1008 if (getNumOperands() == 0 && I->getNumOperands() == 0)
1009 return this->hasSameSpecialState(I, /*IgnoreAlignment=*/false,
1010 IntersectAttrs);
1011
1012 // We have two instructions of identical opcode and #operands. Check to see
1013 // if all operands are the same.
1014 if (!equal(operands(), I->operands()))
1015 return false;
1016
1017 // WARNING: this logic must be kept in sync with EliminateDuplicatePHINodes()!
1018 if (const PHINode *Phi = dyn_cast<PHINode>(this)) {
1019 const PHINode *OtherPhi = cast<PHINode>(I);
1020 return equal(Phi->blocks(), OtherPhi->blocks());
1021 }
1022
1023 return this->hasSameSpecialState(I, /*IgnoreAlignment=*/false,
1024 IntersectAttrs);
1025}
1026
1027// Keep this in sync with FunctionComparator::cmpOperations in
1028// lib/Transforms/IPO/MergeFunctions.cpp.
1030 unsigned flags) const {
1031 bool IgnoreAlignment = flags & CompareIgnoringAlignment;
1032 bool UseScalarTypes = flags & CompareUsingScalarTypes;
1033 bool IntersectAttrs = flags & CompareUsingIntersectedAttrs;
1034
1035 if (getOpcode() != I->getOpcode() ||
1036 getNumOperands() != I->getNumOperands() ||
1037 (UseScalarTypes ?
1038 getType()->getScalarType() != I->getType()->getScalarType() :
1039 getType() != I->getType()))
1040 return false;
1041
1042 // We have two instructions of identical opcode and #operands. Check to see
1043 // if all operands are the same type
1044 for (unsigned i = 0, e = getNumOperands(); i != e; ++i)
1045 if (UseScalarTypes ?
1046 getOperand(i)->getType()->getScalarType() !=
1047 I->getOperand(i)->getType()->getScalarType() :
1048 getOperand(i)->getType() != I->getOperand(i)->getType())
1049 return false;
1050
1051 return this->hasSameSpecialState(I, IgnoreAlignment, IntersectAttrs);
1052}
1053
1054bool Instruction::isUsedOutsideOfBlock(const BasicBlock *BB) const {
1055 for (const Use &U : uses()) {
1056 // PHI nodes uses values in the corresponding predecessor block. For other
1057 // instructions, just check to see whether the parent of the use matches up.
1058 const Instruction *I = cast<Instruction>(U.getUser());
1059 const PHINode *PN = dyn_cast<PHINode>(I);
1060 if (!PN) {
1061 if (I->getParent() != BB)
1062 return true;
1063 continue;
1064 }
1065
1066 if (PN->getIncomingBlock(U) != BB)
1067 return true;
1068 }
1069 return false;
1070}
1071
1073 auto GetEffects = [](ModRefInfo BaseMR, AtomicOrdering Ordering,
1074 bool IsVolatile) {
1075 if (isStrongerThanMonotonic(Ordering))
1076 return MemoryEffects::unknown();
1077
1078 if (IsVolatile)
1080
1081 if (isStrongerThanUnordered(Ordering))
1083
1084 return MemoryEffects::argMemOnly(BaseMR);
1085 };
1086 switch (getOpcode()) {
1087 default:
1088 return MemoryEffects::none();
1089 case Instruction::VAArg:
1091 case Instruction::CatchPad:
1092 case Instruction::CatchRet:
1093 case Instruction::Fence:
1094 return MemoryEffects::unknown();
1095 case Instruction::Call:
1096 case Instruction::Invoke:
1097 case Instruction::CallBr:
1098 return cast<CallBase>(this)->getMemoryEffects();
1099 case Instruction::Load: {
1100 auto *LI = cast<LoadInst>(this);
1101 return GetEffects(ModRefInfo::Ref, LI->getOrdering(), LI->isVolatile());
1102 }
1103 case Instruction::Store: {
1104 auto *SI = cast<StoreInst>(this);
1105 return GetEffects(ModRefInfo::Mod, SI->getOrdering(), SI->isVolatile());
1106 }
1107 case Instruction::AtomicRMW: {
1108 auto *RMW = cast<AtomicRMWInst>(this);
1109 return GetEffects(ModRefInfo::ModRef, RMW->getOrdering(),
1110 RMW->isVolatile());
1111 }
1112 case Instruction::AtomicCmpXchg: {
1113 auto *CX = cast<AtomicCmpXchgInst>(this);
1114 return GetEffects(ModRefInfo::ModRef, CX->getSuccessOrdering(),
1115 CX->isVolatile());
1116 }
1117 }
1118}
1119
1120// This is duplicating the logic from getMemoryEffects() for performance
1121// reasons. Computing the full MemoryEffects just to perform a Mod/Ref check
1122// is expensive.
1123
1124bool Instruction::mayReadFromMemory() const {
1125 switch (getOpcode()) {
1126 default: return false;
1127 case Instruction::VAArg:
1128 case Instruction::Load:
1129 case Instruction::Fence: // FIXME: refine definition of mayReadFromMemory
1130 case Instruction::AtomicCmpXchg:
1131 case Instruction::AtomicRMW:
1132 case Instruction::CatchPad:
1133 case Instruction::CatchRet:
1134 return true;
1135 case Instruction::Call:
1136 case Instruction::Invoke:
1137 case Instruction::CallBr:
1138 return !cast<CallBase>(this)->onlyWritesMemory();
1139 case Instruction::Store:
1140 return !cast<StoreInst>(this)->isUnordered();
1141 }
1142}
1143
1144bool Instruction::mayWriteToMemory() const {
1145 switch (getOpcode()) {
1146 default: return false;
1147 case Instruction::Fence: // FIXME: refine definition of mayWriteToMemory
1148 case Instruction::Store:
1149 case Instruction::VAArg:
1150 case Instruction::AtomicCmpXchg:
1151 case Instruction::AtomicRMW:
1152 case Instruction::CatchPad:
1153 case Instruction::CatchRet:
1154 return true;
1155 case Instruction::Call:
1156 case Instruction::Invoke:
1157 case Instruction::CallBr:
1158 return !cast<CallBase>(this)->onlyReadsMemory();
1159 case Instruction::Load:
1160 return !cast<LoadInst>(this)->isUnordered();
1161 }
1162}
1163
1164bool Instruction::isAtomic() const {
1165 switch (getOpcode()) {
1166 default:
1167 return false;
1168 case Instruction::AtomicCmpXchg:
1169 case Instruction::AtomicRMW:
1170 case Instruction::Fence:
1171 return true;
1172 case Instruction::Load:
1173 return cast<LoadInst>(this)->getOrdering() != AtomicOrdering::NotAtomic;
1174 case Instruction::Store:
1175 return cast<StoreInst>(this)->getOrdering() != AtomicOrdering::NotAtomic;
1176 }
1177}
1178
1179bool Instruction::hasAtomicLoad() const {
1180 assert(isAtomic());
1181 switch (getOpcode()) {
1182 default:
1183 return false;
1184 case Instruction::AtomicCmpXchg:
1185 case Instruction::AtomicRMW:
1186 case Instruction::Load:
1187 return true;
1188 }
1189}
1190
1191bool Instruction::hasAtomicStore() const {
1192 assert(isAtomic());
1193 switch (getOpcode()) {
1194 default:
1195 return false;
1196 case Instruction::AtomicCmpXchg:
1197 case Instruction::AtomicRMW:
1198 case Instruction::Store:
1199 return true;
1200 }
1201}
1202
1203bool Instruction::isVolatile() const {
1204 switch (getOpcode()) {
1205 default:
1206 return false;
1207 case Instruction::AtomicRMW:
1208 return cast<AtomicRMWInst>(this)->isVolatile();
1209 case Instruction::Store:
1210 return cast<StoreInst>(this)->isVolatile();
1211 case Instruction::Load:
1212 return cast<LoadInst>(this)->isVolatile();
1213 case Instruction::AtomicCmpXchg:
1214 return cast<AtomicCmpXchgInst>(this)->isVolatile();
1215 case Instruction::Call:
1216 case Instruction::Invoke:
1217 // There are a very limited number of intrinsics with volatile flags.
1218 if (auto *II = dyn_cast<IntrinsicInst>(this)) {
1219 if (auto *MI = dyn_cast<MemIntrinsic>(II))
1220 return MI->isVolatile();
1221 switch (II->getIntrinsicID()) {
1222 default: break;
1223 case Intrinsic::matrix_column_major_load:
1224 return cast<ConstantInt>(II->getArgOperand(2))->isOne();
1225 case Intrinsic::matrix_column_major_store:
1226 return cast<ConstantInt>(II->getArgOperand(3))->isOne();
1227 }
1228 }
1229 return false;
1230 }
1231}
1232
1233bool Instruction::maySynchronize() const {
1234 // FIXME: This currently treats atomics with monotonic ordering as
1235 // synchronizing. This is unnecessarily conservative and does not match
1236 // our LangRef definition of the property.
1237 switch (getOpcode()) {
1238 default:
1239 assert(!isAtomic() && "Unhandled atomic instruction");
1240 return false;
1241 case Instruction::Fence: {
1242 // All legal orderings for fence are stronger than monotonic.
1243 auto *FI = cast<FenceInst>(this);
1244 return FI->getSyncScopeID() != SyncScope::SingleThread;
1245 }
1246 case Instruction::AtomicRMW:
1247 case Instruction::AtomicCmpXchg:
1248 return true;
1249 case Instruction::Store:
1250 return isStrongerThanUnordered(cast<StoreInst>(this)->getOrdering());
1251 case Instruction::Load:
1252 return isStrongerThanUnordered(cast<LoadInst>(this)->getOrdering());
1253 case Instruction::Call:
1254 case Instruction::Invoke:
1255 case Instruction::CallBr:
1256 return !cast<CallBase>(this)->hasFnAttr(Attribute::NoSync);
1257 }
1258}
1259
1260Type *Instruction::getAccessType() const {
1261 switch (getOpcode()) {
1262 case Instruction::Store:
1263 return cast<StoreInst>(this)->getValueOperand()->getType();
1264 case Instruction::Load:
1265 case Instruction::AtomicRMW:
1266 return getType();
1267 case Instruction::AtomicCmpXchg:
1268 return cast<AtomicCmpXchgInst>(this)->getNewValOperand()->getType();
1269 case Instruction::Call:
1270 case Instruction::Invoke:
1271 if (const IntrinsicInst *II = dyn_cast<IntrinsicInst>(this)) {
1272 switch (II->getIntrinsicID()) {
1273 case Intrinsic::masked_load:
1274 case Intrinsic::masked_gather:
1275 case Intrinsic::masked_expandload:
1276 case Intrinsic::vp_load:
1277 case Intrinsic::vp_gather:
1278 case Intrinsic::experimental_vp_strided_load:
1279 return II->getType();
1280 case Intrinsic::masked_store:
1281 case Intrinsic::masked_scatter:
1282 case Intrinsic::masked_compressstore:
1283 case Intrinsic::vp_store:
1284 case Intrinsic::vp_scatter:
1285 case Intrinsic::experimental_vp_strided_store:
1286 return II->getOperand(0)->getType();
1287 default:
1288 break;
1289 }
1290 }
1291 }
1292
1293 return nullptr;
1294}
1295
1296static bool canUnwindPastLandingPad(const LandingPadInst *LP,
1297 bool IncludePhaseOneUnwind) {
1298 // Because phase one unwinding skips cleanup landingpads, we effectively
1299 // unwind past this frame, and callers need to have valid unwind info.
1300 if (LP->isCleanup())
1301 return IncludePhaseOneUnwind;
1302
1303 for (unsigned I = 0; I < LP->getNumClauses(); ++I) {
1304 Constant *Clause = LP->getClause(I);
1305 // catch ptr null catches all exceptions.
1306 if (LP->isCatch(I) && isa<ConstantPointerNull>(Clause))
1307 return false;
1308 // filter [0 x ptr] catches all exceptions.
1309 if (LP->isFilter(I) && Clause->getType()->getArrayNumElements() == 0)
1310 return false;
1311 }
1312
1313 // May catch only some subset of exceptions, in which case other exceptions
1314 // will continue unwinding.
1315 return true;
1316}
1317
1318bool Instruction::mayThrow(bool IncludePhaseOneUnwind) const {
1319 switch (getOpcode()) {
1320 case Instruction::Call:
1321 return !cast<CallInst>(this)->doesNotThrow();
1322 case Instruction::CleanupRet:
1323 return cast<CleanupReturnInst>(this)->unwindsToCaller();
1324 case Instruction::CatchSwitch:
1325 return cast<CatchSwitchInst>(this)->unwindsToCaller();
1326 case Instruction::Resume:
1327 return true;
1328 case Instruction::Invoke: {
1329 // Landingpads themselves don't unwind -- however, an invoke of a skipped
1330 // landingpad may continue unwinding.
1331 BasicBlock *UnwindDest = cast<InvokeInst>(this)->getUnwindDest();
1332 BasicBlock::iterator Pad = UnwindDest->getFirstNonPHIIt();
1333 if (auto *LP = dyn_cast<LandingPadInst>(Pad))
1334 return canUnwindPastLandingPad(LP, IncludePhaseOneUnwind);
1335 return false;
1336 }
1337 case Instruction::CleanupPad:
1338 // Treat the same as cleanup landingpad.
1339 return IncludePhaseOneUnwind;
1340 default:
1341 return false;
1342 }
1343}
1344
1346 return mayWriteToMemory() || mayThrow() || !willReturn();
1347}
1348
1349bool Instruction::isSafeToRemove() const {
1350 return (!isa<CallInst>(this) || !this->mayHaveSideEffects()) &&
1351 !this->isTerminator() && !this->isEHPad();
1352}
1353
1354bool Instruction::willReturn() const {
1355 // Volatile operations are not guaranteed to return.
1356 if (isVolatile())
1357 return false;
1358
1359 if (const auto *CB = dyn_cast<CallBase>(this))
1360 return CB->hasFnAttr(Attribute::WillReturn);
1361 return true;
1362}
1363
1365 auto *II = dyn_cast<IntrinsicInst>(this);
1366 if (!II)
1367 return false;
1368 Intrinsic::ID ID = II->getIntrinsicID();
1369 return ID == Intrinsic::lifetime_start || ID == Intrinsic::lifetime_end;
1370}
1371
1373 auto *II = dyn_cast<IntrinsicInst>(this);
1374 if (!II)
1375 return false;
1376 Intrinsic::ID ID = II->getIntrinsicID();
1377 return ID == Intrinsic::launder_invariant_group ||
1378 ID == Intrinsic::strip_invariant_group;
1379}
1380
1382 return isa<DbgInfoIntrinsic>(this) || isa<PseudoProbeInst>(this);
1383}
1384
1386 return getDebugLoc();
1387}
1388
1389bool Instruction::isAssociative() const {
1390 if (auto *II = dyn_cast<IntrinsicInst>(this))
1391 return II->isAssociative();
1392 unsigned Opcode = getOpcode();
1393 if (isAssociative(Opcode))
1394 return true;
1395
1396 switch (Opcode) {
1397 case FMul:
1398 return cast<FPMathOperator>(this)->hasAllowReassoc();
1399 case FAdd:
1400 return cast<FPMathOperator>(this)->hasAllowReassoc() &&
1401 cast<FPMathOperator>(this)->hasNoSignedZeros();
1402 default:
1403 return false;
1404 }
1405}
1406
1407bool Instruction::isCommutative() const {
1408 if (auto *II = dyn_cast<IntrinsicInst>(this))
1409 return II->isCommutative();
1410 // TODO: Should allow icmp/fcmp?
1411 return isCommutative(getOpcode());
1412}
1413
1414bool Instruction::isCommutableOperand(unsigned Op) const {
1415 if (auto *II = dyn_cast<IntrinsicInst>(this))
1416 return II->isCommutableOperand(Op);
1417 // TODO: Should allow icmp/fcmp?
1418 return isCommutative(getOpcode());
1419}
1420
1421unsigned Instruction::getNumSuccessors() const {
1422 switch (getOpcode()) {
1423#define HANDLE_TERM_INST(N, OPC, CLASS) \
1424 case Instruction::OPC: \
1425 return static_cast<const CLASS *>(this)->getNumSuccessors();
1426#include "llvm/IR/Instruction.def"
1427 default:
1428 break;
1429 }
1430 llvm_unreachable("not a terminator");
1431}
1432
1433BasicBlock *Instruction::getSuccessor(unsigned idx) const {
1434 switch (getOpcode()) {
1435#define HANDLE_TERM_INST(N, OPC, CLASS) \
1436 case Instruction::OPC: \
1437 return static_cast<const CLASS *>(this)->getSuccessor(idx);
1438#include "llvm/IR/Instruction.def"
1439 default:
1440 break;
1441 }
1442 llvm_unreachable("not a terminator");
1443}
1444
1445void Instruction::setSuccessor(unsigned idx, BasicBlock *B) {
1446 switch (getOpcode()) {
1447#define HANDLE_TERM_INST(N, OPC, CLASS) \
1448 case Instruction::OPC: \
1449 return static_cast<CLASS *>(this)->setSuccessor(idx, B);
1450#include "llvm/IR/Instruction.def"
1451 default:
1452 break;
1453 }
1454 llvm_unreachable("not a terminator");
1455}
1456
1459 switch (getOpcode()) {
1460#define HANDLE_TERM_INST(N, OPC, CLASS) \
1461 case Instruction::OPC: \
1462 return static_cast<const CLASS *>(this)->successors();
1463#include "llvm/IR/Instruction.def"
1464 default:
1465 break;
1466 }
1467 llvm_unreachable("not a terminator");
1468}
1469
1471 auto Succs = successors();
1472 for (auto I = Succs.begin(), E = Succs.end(); I != E; ++I)
1473 if (*I == OldBB)
1474 I.getUse()->set(NewBB);
1475}
1476
1477Instruction *Instruction::cloneImpl() const {
1478 llvm_unreachable("Subclass of Instruction failed to implement cloneImpl");
1479}
1480
1482 MDNode *ProfileData = getBranchWeightMDNode(*this);
1483 if (!ProfileData)
1484 return;
1485 unsigned FirstIdx = getBranchWeightOffset(ProfileData);
1486 if (ProfileData->getNumOperands() != 2 + FirstIdx)
1487 return;
1488
1489 unsigned SecondIdx = FirstIdx + 1;
1491 // If there are more weights past the second, we can't swap them
1492 if (ProfileData->getNumOperands() > SecondIdx + 1)
1493 return;
1494 for (unsigned Idx = 0; Idx < FirstIdx; ++Idx) {
1495 Ops.push_back(ProfileData->getOperand(Idx));
1496 }
1497 // Switch the order of the weights
1498 Ops.push_back(ProfileData->getOperand(SecondIdx));
1499 Ops.push_back(ProfileData->getOperand(FirstIdx));
1500 setMetadata(LLVMContext::MD_prof,
1501 MDNode::get(ProfileData->getContext(), Ops));
1502}
1503
1504void Instruction::copyMetadata(const Instruction &SrcInst,
1505 ArrayRef<unsigned> WL) {
1506 if (WL.empty() || is_contained(WL, LLVMContext::MD_dbg))
1507 setDebugLoc(SrcInst.getDebugLoc().orElse(getDebugLoc()));
1508
1509 if (!SrcInst.hasMetadata())
1510 return;
1511
1512 SmallDenseSet<unsigned, 4> WLS(WL.begin(), WL.end());
1513
1514 // Otherwise, enumerate and copy over metadata from the old instruction to the
1515 // new one.
1517 SrcInst.getAllMetadataOtherThanDebugLoc(TheMDs);
1518 for (const auto &MD : TheMDs) {
1519 if (WL.empty() || WLS.count(MD.first))
1520 setMetadata(MD.first, MD.second);
1521 }
1522}
1523
1525 Instruction *New = nullptr;
1526 switch (getOpcode()) {
1527 default:
1528 llvm_unreachable("Unhandled Opcode.");
1529#define HANDLE_INST(num, opc, clas) \
1530 case Instruction::opc: \
1531 New = cast<clas>(this)->cloneImpl(); \
1532 break;
1533#include "llvm/IR/Instruction.def"
1534#undef HANDLE_INST
1535 }
1536
1537 New->SubclassOptionalData = SubclassOptionalData;
1538 New->copyMetadata(*this);
1539 return New;
1540}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
AMDGPU Register Bank Select
Rewrite undef for PHI
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.
Hexagon Common GEP
static MaybeAlign getAlign(Value *Ptr)
IRTranslator LLVM IR MI
Module.h This file contains the declarations for the Module class.
static bool hasNoSignedWrap(BinaryOperator &I)
static bool hasNoUnsignedWrap(BinaryOperator &I)
static Value * getOpcode(Value &V, Type &Ty, InstrumentationConfig &IConf, InstrumentorIRBuilderTy &IIRB)
const AbstractManglingParser< Derived, Alloc >::OperatorInfo AbstractManglingParser< Derived, Alloc >::Ops[]
#define I(x, y, z)
Definition MD5.cpp:57
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)
This file contains some templates that are useful if you are working with the STL at all.
static bool canUnwindPastLandingPad(const LandingPadInst *LP, bool IncludePhaseOneUnwind)
static SymbolRef::Type getType(const Symbol *Sym)
Definition TapiFile.cpp:39
static bool isAssociative(const COFFSection &Section)
BinaryOperator * Mul
an instruction to allocate memory on the stack
Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
iterator end() const
Definition ArrayRef.h:130
iterator begin() const
Definition ArrayRef.h:129
bool empty() const
Check if the array is empty.
Definition ArrayRef.h:136
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.
Definition Attributes.h:407
LLVM Basic Block Representation.
Definition BasicBlock.h:62
iterator end()
Definition BasicBlock.h:474
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.
Definition BasicBlock.h:213
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...
Definition BasicBlock.h:170
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.
Definition InstrTypes.h:728
static LLVM_ABI ConstantInt * getFalse(LLVMContext &Context)
A parsed version of the target data layout string in and methods for querying it.
Definition DataLayout.h:64
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.
A debug info location.
Definition DebugLoc.h:124
DebugLoc orElse(DebugLoc Other) const
If this DebugLoc is non-empty, returns this DebugLoc; otherwise, selects Other.
Definition DebugLoc.h:185
This instruction extracts a struct member or array element value from an aggregate value.
Convenience struct for specifying and reasoning about fast-math flags.
Definition FMF.h:23
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)
Definition Instruction.h:56
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 MemoryEffects getMemoryEffects() const LLVM_READONLY
Return memory effects of the instruction.
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 ~Instruction()
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 FastMathFlags getFastMathFlagsOrNone() const LLVM_READONLY
Convenience function for getting fast-math flags, or default-constructed FastMathFlags when not a FPM...
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.
Invoke instruction.
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.
Metadata node.
Definition Metadata.h:1075
const MDOperand & getOperand(unsigned I) const
Definition Metadata.h:1439
ArrayRef< MDOperand > operands() const
Definition Metadata.h:1437
static MDTuple * get(LLVMContext &Context, ArrayRef< Metadata * > MDs)
Definition Metadata.h:1567
unsigned getNumOperands() const
Return number of MDNode operands.
Definition Metadata.h:1445
LLVMContext & getContext() const
Definition Metadata.h:1239
Tracking metadata reference owned by Metadata.
Definition Metadata.h:897
static MemoryEffectsBase argMemOnly(ModRefInfo MR=ModRefInfo::ModRef)
Definition ModRef.h:143
static MemoryEffectsBase inaccessibleOrArgMemOnly(ModRefInfo MR=ModRefInfo::ModRef)
Definition ModRef.h:166
static MemoryEffectsBase none()
Definition ModRef.h:128
static MemoryEffectsBase unknown()
Definition ModRef.h:123
static constexpr const unsigned PoisonGeneratingIDs[]
Metadata IDs that may generate poison.
Definition Metadata.h:146
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).
Definition InstrTypes.h:703
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.
Definition DenseSet.h:301
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.
Multiway switch.
A Use represents the edge between a Value definition and its users.
Definition Use.h:35
static LLVM_ABI void handleRAUW(Value *From, Value *To)
Definition Metadata.cpp:552
LLVMContext & getContext() const
All values hold a context through their type.
Definition Value.h:258
const ParentTy * getParent() const
Definition ilist_node.h:34
self_iterator getIterator()
Definition ilist_node.h:123
void splice(iterator where, iplist_impl &L2)
Definition ilist.h:266
iterator insertAfter(iterator where, pointer New)
Definition ilist.h:174
iterator insert(iterator where, pointer New)
Definition ilist.h:165
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.
constexpr char IsVolatile[]
Key for Kernel::Arg::Metadata::mIsVolatile.
constexpr char Attrs[]
Key for Kernel::Metadata::mAttrs.
unsigned ID
LLVM IR allows to use arbitrary numbers as calling convention identifiers.
Definition CallingConv.h:24
@ SingleThread
Synchronized with respect to signal handlers executing in the same thread.
Definition LLVMContext.h:55
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...
Definition CoroShape.h:31
constexpr double e
NodeAddr< PhiNode * > Phi
Definition RDFGraph.h:390
Context & getContext() const
Definition BasicBlock.h:99
iterator end() const
Definition BasicBlock.h:89
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.
Definition STLExtras.h:315
detail::zippy< detail::zip_shortest, T, U, Args... > zip(T &&t, U &&u, Args &&...args)
zip iterator for two or more iteratable types.
Definition STLExtras.h:830
cl::opt< bool > ProfcheckDisableMetadataFixes
Definition LoopInfo.cpp:60
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.
Definition Casting.h:643
bool isStrongerThanMonotonic(AtomicOrdering AO)
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.
Definition STLExtras.h:2207
bool isStrongerThanUnordered(AtomicOrdering AO)
MemoryEffectsBase< IRMemLocation > MemoryEffects
Summary of how a function affects memory in the program.
Definition ModRef.h:356
bool any_of(R &&range, UnaryPredicate P)
Provide wrappers to std::any_of which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1745
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...
Definition Casting.h:547
auto drop_end(T &&RangeOrContainer, size_t N=1)
Return a range covering RangeOrContainer with the last N elements excluded.
Definition STLExtras.h:322
ModRefInfo
Flags indicating whether a memory access modifies or references memory.
Definition ModRef.h:28
@ Ref
The access may reference the value stored in memory.
Definition ModRef.h:32
@ ModRef
The access may reference and may modify the value stored in memory.
Definition ModRef.h:36
@ Mod
The access may modify the value stored in memory.
Definition ModRef.h:34
@ Other
Any other memory.
Definition ModRef.h:68
@ FSub
Subtraction of floats.
@ Xor
Bitwise or logical XOR of integers.
@ FMul
Product of floats.
@ Sub
Subtraction of integers.
@ Add
Sum of integers.
@ FAdd
Sum of floats.
DWARFExpression::Operation Op
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:559
bool is_contained(R &&Range, const E &Element)
Returns true if Element is found in Range.
Definition STLExtras.h:1946
bool equal(L &&LRange, R &&RRange)
Wrapper function around std::equal to detect if pair-wise elements between two ranges are the same.
Definition STLExtras.h:2145
@ Keep
No function return thunk.
Definition CodeGen.h:162
Summary of memprof metadata on allocations.
Matching combinators.