xref: /freebsd/contrib/llvm-project/llvm/include/llvm/IR/Instructions.h (revision b64c5a0ace59af62eff52bfe110a521dc73c937b)
1 //===- llvm/Instructions.h - Instruction subclass definitions ---*- C++ -*-===//
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 exposes the class definitions of all of the subclasses of the
10 // Instruction class.  This is meant to be an easy way to get access to all
11 // instruction subclasses.
12 //
13 //===----------------------------------------------------------------------===//
14 
15 #ifndef LLVM_IR_INSTRUCTIONS_H
16 #define LLVM_IR_INSTRUCTIONS_H
17 
18 #include "llvm/ADT/ArrayRef.h"
19 #include "llvm/ADT/Bitfields.h"
20 #include "llvm/ADT/MapVector.h"
21 #include "llvm/ADT/STLExtras.h"
22 #include "llvm/ADT/SmallVector.h"
23 #include "llvm/ADT/Twine.h"
24 #include "llvm/ADT/iterator.h"
25 #include "llvm/ADT/iterator_range.h"
26 #include "llvm/IR/CFG.h"
27 #include "llvm/IR/Constant.h"
28 #include "llvm/IR/DerivedTypes.h"
29 #include "llvm/IR/GEPNoWrapFlags.h"
30 #include "llvm/IR/InstrTypes.h"
31 #include "llvm/IR/Instruction.h"
32 #include "llvm/IR/Intrinsics.h"
33 #include "llvm/IR/OperandTraits.h"
34 #include "llvm/IR/Use.h"
35 #include "llvm/IR/User.h"
36 #include "llvm/Support/AtomicOrdering.h"
37 #include "llvm/Support/ErrorHandling.h"
38 #include <cassert>
39 #include <cstddef>
40 #include <cstdint>
41 #include <iterator>
42 #include <optional>
43 
44 namespace llvm {
45 
46 class APFloat;
47 class APInt;
48 class BasicBlock;
49 class ConstantInt;
50 class DataLayout;
51 class StringRef;
52 class Type;
53 class Value;
54 class UnreachableInst;
55 
56 //===----------------------------------------------------------------------===//
57 //                                AllocaInst Class
58 //===----------------------------------------------------------------------===//
59 
60 /// an instruction to allocate memory on the stack
61 class AllocaInst : public UnaryInstruction {
62   Type *AllocatedType;
63 
64   using AlignmentField = AlignmentBitfieldElementT<0>;
65   using UsedWithInAllocaField = BoolBitfieldElementT<AlignmentField::NextBit>;
66   using SwiftErrorField = BoolBitfieldElementT<UsedWithInAllocaField::NextBit>;
67   static_assert(Bitfield::areContiguous<AlignmentField, UsedWithInAllocaField,
68                                         SwiftErrorField>(),
69                 "Bitfields must be contiguous");
70 
71 protected:
72   // Note: Instruction needs to be a friend here to call cloneImpl.
73   friend class Instruction;
74 
75   AllocaInst *cloneImpl() const;
76 
77 public:
78   explicit AllocaInst(Type *Ty, unsigned AddrSpace, Value *ArraySize,
79                       const Twine &Name, InsertPosition InsertBefore);
80 
81   AllocaInst(Type *Ty, unsigned AddrSpace, const Twine &Name,
82              InsertPosition InsertBefore);
83 
84   AllocaInst(Type *Ty, unsigned AddrSpace, Value *ArraySize, Align Align,
85              const Twine &Name = "", InsertPosition InsertBefore = nullptr);
86 
87   /// Return true if there is an allocation size parameter to the allocation
88   /// instruction that is not 1.
89   bool isArrayAllocation() const;
90 
91   /// Get the number of elements allocated. For a simple allocation of a single
92   /// element, this will return a constant 1 value.
93   const Value *getArraySize() const { return getOperand(0); }
94   Value *getArraySize() { return getOperand(0); }
95 
96   /// Overload to return most specific pointer type.
97   PointerType *getType() const {
98     return cast<PointerType>(Instruction::getType());
99   }
100 
101   /// Return the address space for the allocation.
102   unsigned getAddressSpace() const {
103     return getType()->getAddressSpace();
104   }
105 
106   /// Get allocation size in bytes. Returns std::nullopt if size can't be
107   /// determined, e.g. in case of a VLA.
108   std::optional<TypeSize> getAllocationSize(const DataLayout &DL) const;
109 
110   /// Get allocation size in bits. Returns std::nullopt if size can't be
111   /// determined, e.g. in case of a VLA.
112   std::optional<TypeSize> getAllocationSizeInBits(const DataLayout &DL) const;
113 
114   /// Return the type that is being allocated by the instruction.
115   Type *getAllocatedType() const { return AllocatedType; }
116   /// for use only in special circumstances that need to generically
117   /// transform a whole instruction (eg: IR linking and vectorization).
118   void setAllocatedType(Type *Ty) { AllocatedType = Ty; }
119 
120   /// Return the alignment of the memory that is being allocated by the
121   /// instruction.
122   Align getAlign() const {
123     return Align(1ULL << getSubclassData<AlignmentField>());
124   }
125 
126   void setAlignment(Align Align) {
127     setSubclassData<AlignmentField>(Log2(Align));
128   }
129 
130   /// Return true if this alloca is in the entry block of the function and is a
131   /// constant size. If so, the code generator will fold it into the
132   /// prolog/epilog code, so it is basically free.
133   bool isStaticAlloca() const;
134 
135   /// Return true if this alloca is used as an inalloca argument to a call. Such
136   /// allocas are never considered static even if they are in the entry block.
137   bool isUsedWithInAlloca() const {
138     return getSubclassData<UsedWithInAllocaField>();
139   }
140 
141   /// Specify whether this alloca is used to represent the arguments to a call.
142   void setUsedWithInAlloca(bool V) {
143     setSubclassData<UsedWithInAllocaField>(V);
144   }
145 
146   /// Return true if this alloca is used as a swifterror argument to a call.
147   bool isSwiftError() const { return getSubclassData<SwiftErrorField>(); }
148   /// Specify whether this alloca is used to represent a swifterror.
149   void setSwiftError(bool V) { setSubclassData<SwiftErrorField>(V); }
150 
151   // Methods for support type inquiry through isa, cast, and dyn_cast:
152   static bool classof(const Instruction *I) {
153     return (I->getOpcode() == Instruction::Alloca);
154   }
155   static bool classof(const Value *V) {
156     return isa<Instruction>(V) && classof(cast<Instruction>(V));
157   }
158 
159 private:
160   // Shadow Instruction::setInstructionSubclassData with a private forwarding
161   // method so that subclasses cannot accidentally use it.
162   template <typename Bitfield>
163   void setSubclassData(typename Bitfield::Type Value) {
164     Instruction::setSubclassData<Bitfield>(Value);
165   }
166 };
167 
168 //===----------------------------------------------------------------------===//
169 //                                LoadInst Class
170 //===----------------------------------------------------------------------===//
171 
172 /// An instruction for reading from memory. This uses the SubclassData field in
173 /// Value to store whether or not the load is volatile.
174 class LoadInst : public UnaryInstruction {
175   using VolatileField = BoolBitfieldElementT<0>;
176   using AlignmentField = AlignmentBitfieldElementT<VolatileField::NextBit>;
177   using OrderingField = AtomicOrderingBitfieldElementT<AlignmentField::NextBit>;
178   static_assert(
179       Bitfield::areContiguous<VolatileField, AlignmentField, OrderingField>(),
180       "Bitfields must be contiguous");
181 
182   void AssertOK();
183 
184 protected:
185   // Note: Instruction needs to be a friend here to call cloneImpl.
186   friend class Instruction;
187 
188   LoadInst *cloneImpl() const;
189 
190 public:
191   LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr,
192            InsertPosition InsertBefore);
193   LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile,
194            InsertPosition InsertBefore);
195   LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile,
196            Align Align, InsertPosition InsertBefore = nullptr);
197   LoadInst(Type *Ty, Value *Ptr, const Twine &NameStr, bool isVolatile,
198            Align Align, AtomicOrdering Order,
199            SyncScope::ID SSID = SyncScope::System,
200            InsertPosition InsertBefore = nullptr);
201 
202   /// Return true if this is a load from a volatile memory location.
203   bool isVolatile() const { return getSubclassData<VolatileField>(); }
204 
205   /// Specify whether this is a volatile load or not.
206   void setVolatile(bool V) { setSubclassData<VolatileField>(V); }
207 
208   /// Return the alignment of the access that is being performed.
209   Align getAlign() const {
210     return Align(1ULL << (getSubclassData<AlignmentField>()));
211   }
212 
213   void setAlignment(Align Align) {
214     setSubclassData<AlignmentField>(Log2(Align));
215   }
216 
217   /// Returns the ordering constraint of this load instruction.
218   AtomicOrdering getOrdering() const {
219     return getSubclassData<OrderingField>();
220   }
221   /// Sets the ordering constraint of this load instruction.  May not be Release
222   /// or AcquireRelease.
223   void setOrdering(AtomicOrdering Ordering) {
224     setSubclassData<OrderingField>(Ordering);
225   }
226 
227   /// Returns the synchronization scope ID of this load instruction.
228   SyncScope::ID getSyncScopeID() const {
229     return SSID;
230   }
231 
232   /// Sets the synchronization scope ID of this load instruction.
233   void setSyncScopeID(SyncScope::ID SSID) {
234     this->SSID = SSID;
235   }
236 
237   /// Sets the ordering constraint and the synchronization scope ID of this load
238   /// instruction.
239   void setAtomic(AtomicOrdering Ordering,
240                  SyncScope::ID SSID = SyncScope::System) {
241     setOrdering(Ordering);
242     setSyncScopeID(SSID);
243   }
244 
245   bool isSimple() const { return !isAtomic() && !isVolatile(); }
246 
247   bool isUnordered() const {
248     return (getOrdering() == AtomicOrdering::NotAtomic ||
249             getOrdering() == AtomicOrdering::Unordered) &&
250            !isVolatile();
251   }
252 
253   Value *getPointerOperand() { return getOperand(0); }
254   const Value *getPointerOperand() const { return getOperand(0); }
255   static unsigned getPointerOperandIndex() { return 0U; }
256   Type *getPointerOperandType() const { return getPointerOperand()->getType(); }
257 
258   /// Returns the address space of the pointer operand.
259   unsigned getPointerAddressSpace() const {
260     return getPointerOperandType()->getPointerAddressSpace();
261   }
262 
263   // Methods for support type inquiry through isa, cast, and dyn_cast:
264   static bool classof(const Instruction *I) {
265     return I->getOpcode() == Instruction::Load;
266   }
267   static bool classof(const Value *V) {
268     return isa<Instruction>(V) && classof(cast<Instruction>(V));
269   }
270 
271 private:
272   // Shadow Instruction::setInstructionSubclassData with a private forwarding
273   // method so that subclasses cannot accidentally use it.
274   template <typename Bitfield>
275   void setSubclassData(typename Bitfield::Type Value) {
276     Instruction::setSubclassData<Bitfield>(Value);
277   }
278 
279   /// The synchronization scope ID of this load instruction.  Not quite enough
280   /// room in SubClassData for everything, so synchronization scope ID gets its
281   /// own field.
282   SyncScope::ID SSID;
283 };
284 
285 //===----------------------------------------------------------------------===//
286 //                                StoreInst Class
287 //===----------------------------------------------------------------------===//
288 
289 /// An instruction for storing to memory.
290 class StoreInst : public Instruction {
291   using VolatileField = BoolBitfieldElementT<0>;
292   using AlignmentField = AlignmentBitfieldElementT<VolatileField::NextBit>;
293   using OrderingField = AtomicOrderingBitfieldElementT<AlignmentField::NextBit>;
294   static_assert(
295       Bitfield::areContiguous<VolatileField, AlignmentField, OrderingField>(),
296       "Bitfields must be contiguous");
297 
298   void AssertOK();
299 
300 protected:
301   // Note: Instruction needs to be a friend here to call cloneImpl.
302   friend class Instruction;
303 
304   StoreInst *cloneImpl() const;
305 
306 public:
307   StoreInst(Value *Val, Value *Ptr, InsertPosition InsertBefore);
308   StoreInst(Value *Val, Value *Ptr, bool isVolatile,
309             InsertPosition InsertBefore);
310   StoreInst(Value *Val, Value *Ptr, bool isVolatile, Align Align,
311             InsertPosition InsertBefore = nullptr);
312   StoreInst(Value *Val, Value *Ptr, bool isVolatile, Align Align,
313             AtomicOrdering Order, SyncScope::ID SSID = SyncScope::System,
314             InsertPosition InsertBefore = nullptr);
315 
316   // allocate space for exactly two operands
317   void *operator new(size_t S) { return User::operator new(S, 2); }
318   void operator delete(void *Ptr) { User::operator delete(Ptr); }
319 
320   /// Return true if this is a store to a volatile memory location.
321   bool isVolatile() const { return getSubclassData<VolatileField>(); }
322 
323   /// Specify whether this is a volatile store or not.
324   void setVolatile(bool V) { setSubclassData<VolatileField>(V); }
325 
326   /// Transparently provide more efficient getOperand methods.
327   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
328 
329   Align getAlign() const {
330     return Align(1ULL << (getSubclassData<AlignmentField>()));
331   }
332 
333   void setAlignment(Align Align) {
334     setSubclassData<AlignmentField>(Log2(Align));
335   }
336 
337   /// Returns the ordering constraint of this store instruction.
338   AtomicOrdering getOrdering() const {
339     return getSubclassData<OrderingField>();
340   }
341 
342   /// Sets the ordering constraint of this store instruction.  May not be
343   /// Acquire or AcquireRelease.
344   void setOrdering(AtomicOrdering Ordering) {
345     setSubclassData<OrderingField>(Ordering);
346   }
347 
348   /// Returns the synchronization scope ID of this store instruction.
349   SyncScope::ID getSyncScopeID() const {
350     return SSID;
351   }
352 
353   /// Sets the synchronization scope ID of this store instruction.
354   void setSyncScopeID(SyncScope::ID SSID) {
355     this->SSID = SSID;
356   }
357 
358   /// Sets the ordering constraint and the synchronization scope ID of this
359   /// store instruction.
360   void setAtomic(AtomicOrdering Ordering,
361                  SyncScope::ID SSID = SyncScope::System) {
362     setOrdering(Ordering);
363     setSyncScopeID(SSID);
364   }
365 
366   bool isSimple() const { return !isAtomic() && !isVolatile(); }
367 
368   bool isUnordered() const {
369     return (getOrdering() == AtomicOrdering::NotAtomic ||
370             getOrdering() == AtomicOrdering::Unordered) &&
371            !isVolatile();
372   }
373 
374   Value *getValueOperand() { return getOperand(0); }
375   const Value *getValueOperand() const { return getOperand(0); }
376 
377   Value *getPointerOperand() { return getOperand(1); }
378   const Value *getPointerOperand() const { return getOperand(1); }
379   static unsigned getPointerOperandIndex() { return 1U; }
380   Type *getPointerOperandType() const { return getPointerOperand()->getType(); }
381 
382   /// Returns the address space of the pointer operand.
383   unsigned getPointerAddressSpace() const {
384     return getPointerOperandType()->getPointerAddressSpace();
385   }
386 
387   // Methods for support type inquiry through isa, cast, and dyn_cast:
388   static bool classof(const Instruction *I) {
389     return I->getOpcode() == Instruction::Store;
390   }
391   static bool classof(const Value *V) {
392     return isa<Instruction>(V) && classof(cast<Instruction>(V));
393   }
394 
395 private:
396   // Shadow Instruction::setInstructionSubclassData with a private forwarding
397   // method so that subclasses cannot accidentally use it.
398   template <typename Bitfield>
399   void setSubclassData(typename Bitfield::Type Value) {
400     Instruction::setSubclassData<Bitfield>(Value);
401   }
402 
403   /// The synchronization scope ID of this store instruction.  Not quite enough
404   /// room in SubClassData for everything, so synchronization scope ID gets its
405   /// own field.
406   SyncScope::ID SSID;
407 };
408 
409 template <>
410 struct OperandTraits<StoreInst> : public FixedNumOperandTraits<StoreInst, 2> {
411 };
412 
413 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(StoreInst, Value)
414 
415 //===----------------------------------------------------------------------===//
416 //                                FenceInst Class
417 //===----------------------------------------------------------------------===//
418 
419 /// An instruction for ordering other memory operations.
420 class FenceInst : public Instruction {
421   using OrderingField = AtomicOrderingBitfieldElementT<0>;
422 
423   void Init(AtomicOrdering Ordering, SyncScope::ID SSID);
424 
425 protected:
426   // Note: Instruction needs to be a friend here to call cloneImpl.
427   friend class Instruction;
428 
429   FenceInst *cloneImpl() const;
430 
431 public:
432   // Ordering may only be Acquire, Release, AcquireRelease, or
433   // SequentiallyConsistent.
434   FenceInst(LLVMContext &C, AtomicOrdering Ordering,
435             SyncScope::ID SSID = SyncScope::System,
436             InsertPosition InsertBefore = nullptr);
437 
438   // allocate space for exactly zero operands
439   void *operator new(size_t S) { return User::operator new(S, 0); }
440   void operator delete(void *Ptr) { User::operator delete(Ptr); }
441 
442   /// Returns the ordering constraint of this fence instruction.
443   AtomicOrdering getOrdering() const {
444     return getSubclassData<OrderingField>();
445   }
446 
447   /// Sets the ordering constraint of this fence instruction.  May only be
448   /// Acquire, Release, AcquireRelease, or SequentiallyConsistent.
449   void setOrdering(AtomicOrdering Ordering) {
450     setSubclassData<OrderingField>(Ordering);
451   }
452 
453   /// Returns the synchronization scope ID of this fence instruction.
454   SyncScope::ID getSyncScopeID() const {
455     return SSID;
456   }
457 
458   /// Sets the synchronization scope ID of this fence instruction.
459   void setSyncScopeID(SyncScope::ID SSID) {
460     this->SSID = SSID;
461   }
462 
463   // Methods for support type inquiry through isa, cast, and dyn_cast:
464   static bool classof(const Instruction *I) {
465     return I->getOpcode() == Instruction::Fence;
466   }
467   static bool classof(const Value *V) {
468     return isa<Instruction>(V) && classof(cast<Instruction>(V));
469   }
470 
471 private:
472   // Shadow Instruction::setInstructionSubclassData with a private forwarding
473   // method so that subclasses cannot accidentally use it.
474   template <typename Bitfield>
475   void setSubclassData(typename Bitfield::Type Value) {
476     Instruction::setSubclassData<Bitfield>(Value);
477   }
478 
479   /// The synchronization scope ID of this fence instruction.  Not quite enough
480   /// room in SubClassData for everything, so synchronization scope ID gets its
481   /// own field.
482   SyncScope::ID SSID;
483 };
484 
485 //===----------------------------------------------------------------------===//
486 //                                AtomicCmpXchgInst Class
487 //===----------------------------------------------------------------------===//
488 
489 /// An instruction that atomically checks whether a
490 /// specified value is in a memory location, and, if it is, stores a new value
491 /// there. The value returned by this instruction is a pair containing the
492 /// original value as first element, and an i1 indicating success (true) or
493 /// failure (false) as second element.
494 ///
495 class AtomicCmpXchgInst : public Instruction {
496   void Init(Value *Ptr, Value *Cmp, Value *NewVal, Align Align,
497             AtomicOrdering SuccessOrdering, AtomicOrdering FailureOrdering,
498             SyncScope::ID SSID);
499 
500   template <unsigned Offset>
501   using AtomicOrderingBitfieldElement =
502       typename Bitfield::Element<AtomicOrdering, Offset, 3,
503                                  AtomicOrdering::LAST>;
504 
505 protected:
506   // Note: Instruction needs to be a friend here to call cloneImpl.
507   friend class Instruction;
508 
509   AtomicCmpXchgInst *cloneImpl() const;
510 
511 public:
512   AtomicCmpXchgInst(Value *Ptr, Value *Cmp, Value *NewVal, Align Alignment,
513                     AtomicOrdering SuccessOrdering,
514                     AtomicOrdering FailureOrdering, SyncScope::ID SSID,
515                     InsertPosition InsertBefore = nullptr);
516 
517   // allocate space for exactly three operands
518   void *operator new(size_t S) { return User::operator new(S, 3); }
519   void operator delete(void *Ptr) { User::operator delete(Ptr); }
520 
521   using VolatileField = BoolBitfieldElementT<0>;
522   using WeakField = BoolBitfieldElementT<VolatileField::NextBit>;
523   using SuccessOrderingField =
524       AtomicOrderingBitfieldElementT<WeakField::NextBit>;
525   using FailureOrderingField =
526       AtomicOrderingBitfieldElementT<SuccessOrderingField::NextBit>;
527   using AlignmentField =
528       AlignmentBitfieldElementT<FailureOrderingField::NextBit>;
529   static_assert(
530       Bitfield::areContiguous<VolatileField, WeakField, SuccessOrderingField,
531                               FailureOrderingField, AlignmentField>(),
532       "Bitfields must be contiguous");
533 
534   /// Return the alignment of the memory that is being allocated by the
535   /// instruction.
536   Align getAlign() const {
537     return Align(1ULL << getSubclassData<AlignmentField>());
538   }
539 
540   void setAlignment(Align Align) {
541     setSubclassData<AlignmentField>(Log2(Align));
542   }
543 
544   /// Return true if this is a cmpxchg from a volatile memory
545   /// location.
546   ///
547   bool isVolatile() const { return getSubclassData<VolatileField>(); }
548 
549   /// Specify whether this is a volatile cmpxchg.
550   ///
551   void setVolatile(bool V) { setSubclassData<VolatileField>(V); }
552 
553   /// Return true if this cmpxchg may spuriously fail.
554   bool isWeak() const { return getSubclassData<WeakField>(); }
555 
556   void setWeak(bool IsWeak) { setSubclassData<WeakField>(IsWeak); }
557 
558   /// Transparently provide more efficient getOperand methods.
559   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
560 
561   static bool isValidSuccessOrdering(AtomicOrdering Ordering) {
562     return Ordering != AtomicOrdering::NotAtomic &&
563            Ordering != AtomicOrdering::Unordered;
564   }
565 
566   static bool isValidFailureOrdering(AtomicOrdering Ordering) {
567     return Ordering != AtomicOrdering::NotAtomic &&
568            Ordering != AtomicOrdering::Unordered &&
569            Ordering != AtomicOrdering::AcquireRelease &&
570            Ordering != AtomicOrdering::Release;
571   }
572 
573   /// Returns the success ordering constraint of this cmpxchg instruction.
574   AtomicOrdering getSuccessOrdering() const {
575     return getSubclassData<SuccessOrderingField>();
576   }
577 
578   /// Sets the success ordering constraint of this cmpxchg instruction.
579   void setSuccessOrdering(AtomicOrdering Ordering) {
580     assert(isValidSuccessOrdering(Ordering) &&
581            "invalid CmpXchg success ordering");
582     setSubclassData<SuccessOrderingField>(Ordering);
583   }
584 
585   /// Returns the failure ordering constraint of this cmpxchg instruction.
586   AtomicOrdering getFailureOrdering() const {
587     return getSubclassData<FailureOrderingField>();
588   }
589 
590   /// Sets the failure ordering constraint of this cmpxchg instruction.
591   void setFailureOrdering(AtomicOrdering Ordering) {
592     assert(isValidFailureOrdering(Ordering) &&
593            "invalid CmpXchg failure ordering");
594     setSubclassData<FailureOrderingField>(Ordering);
595   }
596 
597   /// Returns a single ordering which is at least as strong as both the
598   /// success and failure orderings for this cmpxchg.
599   AtomicOrdering getMergedOrdering() const {
600     if (getFailureOrdering() == AtomicOrdering::SequentiallyConsistent)
601       return AtomicOrdering::SequentiallyConsistent;
602     if (getFailureOrdering() == AtomicOrdering::Acquire) {
603       if (getSuccessOrdering() == AtomicOrdering::Monotonic)
604         return AtomicOrdering::Acquire;
605       if (getSuccessOrdering() == AtomicOrdering::Release)
606         return AtomicOrdering::AcquireRelease;
607     }
608     return getSuccessOrdering();
609   }
610 
611   /// Returns the synchronization scope ID of this cmpxchg instruction.
612   SyncScope::ID getSyncScopeID() const {
613     return SSID;
614   }
615 
616   /// Sets the synchronization scope ID of this cmpxchg instruction.
617   void setSyncScopeID(SyncScope::ID SSID) {
618     this->SSID = SSID;
619   }
620 
621   Value *getPointerOperand() { return getOperand(0); }
622   const Value *getPointerOperand() const { return getOperand(0); }
623   static unsigned getPointerOperandIndex() { return 0U; }
624 
625   Value *getCompareOperand() { return getOperand(1); }
626   const Value *getCompareOperand() const { return getOperand(1); }
627 
628   Value *getNewValOperand() { return getOperand(2); }
629   const Value *getNewValOperand() const { return getOperand(2); }
630 
631   /// Returns the address space of the pointer operand.
632   unsigned getPointerAddressSpace() const {
633     return getPointerOperand()->getType()->getPointerAddressSpace();
634   }
635 
636   /// Returns the strongest permitted ordering on failure, given the
637   /// desired ordering on success.
638   ///
639   /// If the comparison in a cmpxchg operation fails, there is no atomic store
640   /// so release semantics cannot be provided. So this function drops explicit
641   /// Release requests from the AtomicOrdering. A SequentiallyConsistent
642   /// operation would remain SequentiallyConsistent.
643   static AtomicOrdering
644   getStrongestFailureOrdering(AtomicOrdering SuccessOrdering) {
645     switch (SuccessOrdering) {
646     default:
647       llvm_unreachable("invalid cmpxchg success ordering");
648     case AtomicOrdering::Release:
649     case AtomicOrdering::Monotonic:
650       return AtomicOrdering::Monotonic;
651     case AtomicOrdering::AcquireRelease:
652     case AtomicOrdering::Acquire:
653       return AtomicOrdering::Acquire;
654     case AtomicOrdering::SequentiallyConsistent:
655       return AtomicOrdering::SequentiallyConsistent;
656     }
657   }
658 
659   // Methods for support type inquiry through isa, cast, and dyn_cast:
660   static bool classof(const Instruction *I) {
661     return I->getOpcode() == Instruction::AtomicCmpXchg;
662   }
663   static bool classof(const Value *V) {
664     return isa<Instruction>(V) && classof(cast<Instruction>(V));
665   }
666 
667 private:
668   // Shadow Instruction::setInstructionSubclassData with a private forwarding
669   // method so that subclasses cannot accidentally use it.
670   template <typename Bitfield>
671   void setSubclassData(typename Bitfield::Type Value) {
672     Instruction::setSubclassData<Bitfield>(Value);
673   }
674 
675   /// The synchronization scope ID of this cmpxchg instruction.  Not quite
676   /// enough room in SubClassData for everything, so synchronization scope ID
677   /// gets its own field.
678   SyncScope::ID SSID;
679 };
680 
681 template <>
682 struct OperandTraits<AtomicCmpXchgInst> :
683     public FixedNumOperandTraits<AtomicCmpXchgInst, 3> {
684 };
685 
686 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(AtomicCmpXchgInst, Value)
687 
688 //===----------------------------------------------------------------------===//
689 //                                AtomicRMWInst Class
690 //===----------------------------------------------------------------------===//
691 
692 /// an instruction that atomically reads a memory location,
693 /// combines it with another value, and then stores the result back.  Returns
694 /// the old value.
695 ///
696 class AtomicRMWInst : public Instruction {
697 protected:
698   // Note: Instruction needs to be a friend here to call cloneImpl.
699   friend class Instruction;
700 
701   AtomicRMWInst *cloneImpl() const;
702 
703 public:
704   /// This enumeration lists the possible modifications atomicrmw can make.  In
705   /// the descriptions, 'p' is the pointer to the instruction's memory location,
706   /// 'old' is the initial value of *p, and 'v' is the other value passed to the
707   /// instruction.  These instructions always return 'old'.
708   enum BinOp : unsigned {
709     /// *p = v
710     Xchg,
711     /// *p = old + v
712     Add,
713     /// *p = old - v
714     Sub,
715     /// *p = old & v
716     And,
717     /// *p = ~(old & v)
718     Nand,
719     /// *p = old | v
720     Or,
721     /// *p = old ^ v
722     Xor,
723     /// *p = old >signed v ? old : v
724     Max,
725     /// *p = old <signed v ? old : v
726     Min,
727     /// *p = old >unsigned v ? old : v
728     UMax,
729     /// *p = old <unsigned v ? old : v
730     UMin,
731 
732     /// *p = old + v
733     FAdd,
734 
735     /// *p = old - v
736     FSub,
737 
738     /// *p = maxnum(old, v)
739     /// \p maxnum matches the behavior of \p llvm.maxnum.*.
740     FMax,
741 
742     /// *p = minnum(old, v)
743     /// \p minnum matches the behavior of \p llvm.minnum.*.
744     FMin,
745 
746     /// Increment one up to a maximum value.
747     /// *p = (old u>= v) ? 0 : (old + 1)
748     UIncWrap,
749 
750     /// Decrement one until a minimum value or zero.
751     /// *p = ((old == 0) || (old u> v)) ? v : (old - 1)
752     UDecWrap,
753 
754     FIRST_BINOP = Xchg,
755     LAST_BINOP = UDecWrap,
756     BAD_BINOP
757   };
758 
759 private:
760   template <unsigned Offset>
761   using AtomicOrderingBitfieldElement =
762       typename Bitfield::Element<AtomicOrdering, Offset, 3,
763                                  AtomicOrdering::LAST>;
764 
765   template <unsigned Offset>
766   using BinOpBitfieldElement =
767       typename Bitfield::Element<BinOp, Offset, 5, BinOp::LAST_BINOP>;
768 
769 public:
770   AtomicRMWInst(BinOp Operation, Value *Ptr, Value *Val, Align Alignment,
771                 AtomicOrdering Ordering, SyncScope::ID SSID,
772                 InsertPosition InsertBefore = nullptr);
773 
774   // allocate space for exactly two operands
775   void *operator new(size_t S) { return User::operator new(S, 2); }
776   void operator delete(void *Ptr) { User::operator delete(Ptr); }
777 
778   using VolatileField = BoolBitfieldElementT<0>;
779   using AtomicOrderingField =
780       AtomicOrderingBitfieldElementT<VolatileField::NextBit>;
781   using OperationField = BinOpBitfieldElement<AtomicOrderingField::NextBit>;
782   using AlignmentField = AlignmentBitfieldElementT<OperationField::NextBit>;
783   static_assert(Bitfield::areContiguous<VolatileField, AtomicOrderingField,
784                                         OperationField, AlignmentField>(),
785                 "Bitfields must be contiguous");
786 
787   BinOp getOperation() const { return getSubclassData<OperationField>(); }
788 
789   static StringRef getOperationName(BinOp Op);
790 
791   static bool isFPOperation(BinOp Op) {
792     switch (Op) {
793     case AtomicRMWInst::FAdd:
794     case AtomicRMWInst::FSub:
795     case AtomicRMWInst::FMax:
796     case AtomicRMWInst::FMin:
797       return true;
798     default:
799       return false;
800     }
801   }
802 
803   void setOperation(BinOp Operation) {
804     setSubclassData<OperationField>(Operation);
805   }
806 
807   /// Return the alignment of the memory that is being allocated by the
808   /// instruction.
809   Align getAlign() const {
810     return Align(1ULL << getSubclassData<AlignmentField>());
811   }
812 
813   void setAlignment(Align Align) {
814     setSubclassData<AlignmentField>(Log2(Align));
815   }
816 
817   /// Return true if this is a RMW on a volatile memory location.
818   ///
819   bool isVolatile() const { return getSubclassData<VolatileField>(); }
820 
821   /// Specify whether this is a volatile RMW or not.
822   ///
823   void setVolatile(bool V) { setSubclassData<VolatileField>(V); }
824 
825   /// Transparently provide more efficient getOperand methods.
826   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
827 
828   /// Returns the ordering constraint of this rmw instruction.
829   AtomicOrdering getOrdering() const {
830     return getSubclassData<AtomicOrderingField>();
831   }
832 
833   /// Sets the ordering constraint of this rmw instruction.
834   void setOrdering(AtomicOrdering Ordering) {
835     assert(Ordering != AtomicOrdering::NotAtomic &&
836            "atomicrmw instructions can only be atomic.");
837     assert(Ordering != AtomicOrdering::Unordered &&
838            "atomicrmw instructions cannot be unordered.");
839     setSubclassData<AtomicOrderingField>(Ordering);
840   }
841 
842   /// Returns the synchronization scope ID of this rmw instruction.
843   SyncScope::ID getSyncScopeID() const {
844     return SSID;
845   }
846 
847   /// Sets the synchronization scope ID of this rmw instruction.
848   void setSyncScopeID(SyncScope::ID SSID) {
849     this->SSID = SSID;
850   }
851 
852   Value *getPointerOperand() { return getOperand(0); }
853   const Value *getPointerOperand() const { return getOperand(0); }
854   static unsigned getPointerOperandIndex() { return 0U; }
855 
856   Value *getValOperand() { return getOperand(1); }
857   const Value *getValOperand() const { return getOperand(1); }
858 
859   /// Returns the address space of the pointer operand.
860   unsigned getPointerAddressSpace() const {
861     return getPointerOperand()->getType()->getPointerAddressSpace();
862   }
863 
864   bool isFloatingPointOperation() const {
865     return isFPOperation(getOperation());
866   }
867 
868   // Methods for support type inquiry through isa, cast, and dyn_cast:
869   static bool classof(const Instruction *I) {
870     return I->getOpcode() == Instruction::AtomicRMW;
871   }
872   static bool classof(const Value *V) {
873     return isa<Instruction>(V) && classof(cast<Instruction>(V));
874   }
875 
876 private:
877   void Init(BinOp Operation, Value *Ptr, Value *Val, Align Align,
878             AtomicOrdering Ordering, SyncScope::ID SSID);
879 
880   // Shadow Instruction::setInstructionSubclassData with a private forwarding
881   // method so that subclasses cannot accidentally use it.
882   template <typename Bitfield>
883   void setSubclassData(typename Bitfield::Type Value) {
884     Instruction::setSubclassData<Bitfield>(Value);
885   }
886 
887   /// The synchronization scope ID of this rmw instruction.  Not quite enough
888   /// room in SubClassData for everything, so synchronization scope ID gets its
889   /// own field.
890   SyncScope::ID SSID;
891 };
892 
893 template <>
894 struct OperandTraits<AtomicRMWInst>
895     : public FixedNumOperandTraits<AtomicRMWInst,2> {
896 };
897 
898 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(AtomicRMWInst, Value)
899 
900 //===----------------------------------------------------------------------===//
901 //                             GetElementPtrInst Class
902 //===----------------------------------------------------------------------===//
903 
904 // checkGEPType - Simple wrapper function to give a better assertion failure
905 // message on bad indexes for a gep instruction.
906 //
907 inline Type *checkGEPType(Type *Ty) {
908   assert(Ty && "Invalid GetElementPtrInst indices for type!");
909   return Ty;
910 }
911 
912 /// an instruction for type-safe pointer arithmetic to
913 /// access elements of arrays and structs
914 ///
915 class GetElementPtrInst : public Instruction {
916   Type *SourceElementType;
917   Type *ResultElementType;
918 
919   GetElementPtrInst(const GetElementPtrInst &GEPI);
920 
921   /// Constructors - Create a getelementptr instruction with a base pointer an
922   /// list of indices. The first and second ctor can optionally insert before an
923   /// existing instruction, the third appends the new instruction to the
924   /// specified BasicBlock.
925   inline GetElementPtrInst(Type *PointeeType, Value *Ptr,
926                            ArrayRef<Value *> IdxList, unsigned Values,
927                            const Twine &NameStr, InsertPosition InsertBefore);
928 
929   void init(Value *Ptr, ArrayRef<Value *> IdxList, const Twine &NameStr);
930 
931 protected:
932   // Note: Instruction needs to be a friend here to call cloneImpl.
933   friend class Instruction;
934 
935   GetElementPtrInst *cloneImpl() const;
936 
937 public:
938   static GetElementPtrInst *Create(Type *PointeeType, Value *Ptr,
939                                    ArrayRef<Value *> IdxList,
940                                    const Twine &NameStr = "",
941                                    InsertPosition InsertBefore = nullptr) {
942     unsigned Values = 1 + unsigned(IdxList.size());
943     assert(PointeeType && "Must specify element type");
944     return new (Values) GetElementPtrInst(PointeeType, Ptr, IdxList, Values,
945                                           NameStr, InsertBefore);
946   }
947 
948   static GetElementPtrInst *Create(Type *PointeeType, Value *Ptr,
949                                    ArrayRef<Value *> IdxList, GEPNoWrapFlags NW,
950                                    const Twine &NameStr = "",
951                                    InsertPosition InsertBefore = nullptr) {
952     GetElementPtrInst *GEP =
953         Create(PointeeType, Ptr, IdxList, NameStr, InsertBefore);
954     GEP->setNoWrapFlags(NW);
955     return GEP;
956   }
957 
958   /// Create an "inbounds" getelementptr. See the documentation for the
959   /// "inbounds" flag in LangRef.html for details.
960   static GetElementPtrInst *
961   CreateInBounds(Type *PointeeType, Value *Ptr, ArrayRef<Value *> IdxList,
962                  const Twine &NameStr = "",
963                  InsertPosition InsertBefore = nullptr) {
964     return Create(PointeeType, Ptr, IdxList, GEPNoWrapFlags::inBounds(),
965                   NameStr, InsertBefore);
966   }
967 
968   /// Transparently provide more efficient getOperand methods.
969   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
970 
971   Type *getSourceElementType() const { return SourceElementType; }
972 
973   void setSourceElementType(Type *Ty) { SourceElementType = Ty; }
974   void setResultElementType(Type *Ty) { ResultElementType = Ty; }
975 
976   Type *getResultElementType() const {
977     return ResultElementType;
978   }
979 
980   /// Returns the address space of this instruction's pointer type.
981   unsigned getAddressSpace() const {
982     // Note that this is always the same as the pointer operand's address space
983     // and that is cheaper to compute, so cheat here.
984     return getPointerAddressSpace();
985   }
986 
987   /// Returns the result type of a getelementptr with the given source
988   /// element type and indexes.
989   ///
990   /// Null is returned if the indices are invalid for the specified
991   /// source element type.
992   static Type *getIndexedType(Type *Ty, ArrayRef<Value *> IdxList);
993   static Type *getIndexedType(Type *Ty, ArrayRef<Constant *> IdxList);
994   static Type *getIndexedType(Type *Ty, ArrayRef<uint64_t> IdxList);
995 
996   /// Return the type of the element at the given index of an indexable
997   /// type.  This is equivalent to "getIndexedType(Agg, {Zero, Idx})".
998   ///
999   /// Returns null if the type can't be indexed, or the given index is not
1000   /// legal for the given type.
1001   static Type *getTypeAtIndex(Type *Ty, Value *Idx);
1002   static Type *getTypeAtIndex(Type *Ty, uint64_t Idx);
1003 
1004   inline op_iterator       idx_begin()       { return op_begin()+1; }
1005   inline const_op_iterator idx_begin() const { return op_begin()+1; }
1006   inline op_iterator       idx_end()         { return op_end(); }
1007   inline const_op_iterator idx_end()   const { return op_end(); }
1008 
1009   inline iterator_range<op_iterator> indices() {
1010     return make_range(idx_begin(), idx_end());
1011   }
1012 
1013   inline iterator_range<const_op_iterator> indices() const {
1014     return make_range(idx_begin(), idx_end());
1015   }
1016 
1017   Value *getPointerOperand() {
1018     return getOperand(0);
1019   }
1020   const Value *getPointerOperand() const {
1021     return getOperand(0);
1022   }
1023   static unsigned getPointerOperandIndex() {
1024     return 0U;    // get index for modifying correct operand.
1025   }
1026 
1027   /// Method to return the pointer operand as a
1028   /// PointerType.
1029   Type *getPointerOperandType() const {
1030     return getPointerOperand()->getType();
1031   }
1032 
1033   /// Returns the address space of the pointer operand.
1034   unsigned getPointerAddressSpace() const {
1035     return getPointerOperandType()->getPointerAddressSpace();
1036   }
1037 
1038   /// Returns the pointer type returned by the GEP
1039   /// instruction, which may be a vector of pointers.
1040   static Type *getGEPReturnType(Value *Ptr, ArrayRef<Value *> IdxList) {
1041     // Vector GEP
1042     Type *Ty = Ptr->getType();
1043     if (Ty->isVectorTy())
1044       return Ty;
1045 
1046     for (Value *Index : IdxList)
1047       if (auto *IndexVTy = dyn_cast<VectorType>(Index->getType())) {
1048         ElementCount EltCount = IndexVTy->getElementCount();
1049         return VectorType::get(Ty, EltCount);
1050       }
1051     // Scalar GEP
1052     return Ty;
1053   }
1054 
1055   unsigned getNumIndices() const {  // Note: always non-negative
1056     return getNumOperands() - 1;
1057   }
1058 
1059   bool hasIndices() const {
1060     return getNumOperands() > 1;
1061   }
1062 
1063   /// Return true if all of the indices of this GEP are
1064   /// zeros.  If so, the result pointer and the first operand have the same
1065   /// value, just potentially different types.
1066   bool hasAllZeroIndices() const;
1067 
1068   /// Return true if all of the indices of this GEP are
1069   /// constant integers.  If so, the result pointer and the first operand have
1070   /// a constant offset between them.
1071   bool hasAllConstantIndices() const;
1072 
1073   /// Set nowrap flags for GEP instruction.
1074   void setNoWrapFlags(GEPNoWrapFlags NW);
1075 
1076   /// Set or clear the inbounds flag on this GEP instruction.
1077   /// See LangRef.html for the meaning of inbounds on a getelementptr.
1078   /// TODO: Remove this method in favor of setNoWrapFlags().
1079   void setIsInBounds(bool b = true);
1080 
1081   /// Get the nowrap flags for the GEP instruction.
1082   GEPNoWrapFlags getNoWrapFlags() const;
1083 
1084   /// Determine whether the GEP has the inbounds flag.
1085   bool isInBounds() const;
1086 
1087   /// Determine whether the GEP has the nusw flag.
1088   bool hasNoUnsignedSignedWrap() const;
1089 
1090   /// Determine whether the GEP has the nuw flag.
1091   bool hasNoUnsignedWrap() const;
1092 
1093   /// Accumulate the constant address offset of this GEP if possible.
1094   ///
1095   /// This routine accepts an APInt into which it will accumulate the constant
1096   /// offset of this GEP if the GEP is in fact constant. If the GEP is not
1097   /// all-constant, it returns false and the value of the offset APInt is
1098   /// undefined (it is *not* preserved!). The APInt passed into this routine
1099   /// must be at least as wide as the IntPtr type for the address space of
1100   /// the base GEP pointer.
1101   bool accumulateConstantOffset(const DataLayout &DL, APInt &Offset) const;
1102   bool collectOffset(const DataLayout &DL, unsigned BitWidth,
1103                      MapVector<Value *, APInt> &VariableOffsets,
1104                      APInt &ConstantOffset) const;
1105   // Methods for support type inquiry through isa, cast, and dyn_cast:
1106   static bool classof(const Instruction *I) {
1107     return (I->getOpcode() == Instruction::GetElementPtr);
1108   }
1109   static bool classof(const Value *V) {
1110     return isa<Instruction>(V) && classof(cast<Instruction>(V));
1111   }
1112 };
1113 
1114 template <>
1115 struct OperandTraits<GetElementPtrInst> :
1116   public VariadicOperandTraits<GetElementPtrInst, 1> {
1117 };
1118 
1119 GetElementPtrInst::GetElementPtrInst(Type *PointeeType, Value *Ptr,
1120                                      ArrayRef<Value *> IdxList, unsigned Values,
1121                                      const Twine &NameStr,
1122                                      InsertPosition InsertBefore)
1123     : Instruction(getGEPReturnType(Ptr, IdxList), GetElementPtr,
1124                   OperandTraits<GetElementPtrInst>::op_end(this) - Values,
1125                   Values, InsertBefore),
1126       SourceElementType(PointeeType),
1127       ResultElementType(getIndexedType(PointeeType, IdxList)) {
1128   init(Ptr, IdxList, NameStr);
1129 }
1130 
1131 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(GetElementPtrInst, Value)
1132 
1133 //===----------------------------------------------------------------------===//
1134 //                               ICmpInst Class
1135 //===----------------------------------------------------------------------===//
1136 
1137 /// This instruction compares its operands according to the predicate given
1138 /// to the constructor. It only operates on integers or pointers. The operands
1139 /// must be identical types.
1140 /// Represent an integer comparison operator.
1141 class ICmpInst: public CmpInst {
1142   void AssertOK() {
1143     assert(isIntPredicate() &&
1144            "Invalid ICmp predicate value");
1145     assert(getOperand(0)->getType() == getOperand(1)->getType() &&
1146           "Both operands to ICmp instruction are not of the same type!");
1147     // Check that the operands are the right type
1148     assert((getOperand(0)->getType()->isIntOrIntVectorTy() ||
1149             getOperand(0)->getType()->isPtrOrPtrVectorTy()) &&
1150            "Invalid operand types for ICmp instruction");
1151   }
1152 
1153 protected:
1154   // Note: Instruction needs to be a friend here to call cloneImpl.
1155   friend class Instruction;
1156 
1157   /// Clone an identical ICmpInst
1158   ICmpInst *cloneImpl() const;
1159 
1160 public:
1161   /// Constructor with insertion semantics.
1162   ICmpInst(InsertPosition InsertBefore, ///< Where to insert
1163            Predicate pred, ///< The predicate to use for the comparison
1164            Value *LHS,     ///< The left-hand-side of the expression
1165            Value *RHS,     ///< The right-hand-side of the expression
1166            const Twine &NameStr = "" ///< Name of the instruction
1167            )
1168       : CmpInst(makeCmpResultType(LHS->getType()), Instruction::ICmp, pred, LHS,
1169                 RHS, NameStr, InsertBefore) {
1170 #ifndef NDEBUG
1171   AssertOK();
1172 #endif
1173   }
1174 
1175   /// Constructor with no-insertion semantics
1176   ICmpInst(
1177     Predicate pred, ///< The predicate to use for the comparison
1178     Value *LHS,     ///< The left-hand-side of the expression
1179     Value *RHS,     ///< The right-hand-side of the expression
1180     const Twine &NameStr = "" ///< Name of the instruction
1181   ) : CmpInst(makeCmpResultType(LHS->getType()),
1182               Instruction::ICmp, pred, LHS, RHS, NameStr) {
1183 #ifndef NDEBUG
1184   AssertOK();
1185 #endif
1186   }
1187 
1188   /// For example, EQ->EQ, SLE->SLE, UGT->SGT, etc.
1189   /// @returns the predicate that would be the result if the operand were
1190   /// regarded as signed.
1191   /// Return the signed version of the predicate
1192   Predicate getSignedPredicate() const {
1193     return getSignedPredicate(getPredicate());
1194   }
1195 
1196   /// This is a static version that you can use without an instruction.
1197   /// Return the signed version of the predicate.
1198   static Predicate getSignedPredicate(Predicate pred);
1199 
1200   /// For example, EQ->EQ, SLE->ULE, UGT->UGT, etc.
1201   /// @returns the predicate that would be the result if the operand were
1202   /// regarded as unsigned.
1203   /// Return the unsigned version of the predicate
1204   Predicate getUnsignedPredicate() const {
1205     return getUnsignedPredicate(getPredicate());
1206   }
1207 
1208   /// This is a static version that you can use without an instruction.
1209   /// Return the unsigned version of the predicate.
1210   static Predicate getUnsignedPredicate(Predicate pred);
1211 
1212   /// Return true if this predicate is either EQ or NE.  This also
1213   /// tests for commutativity.
1214   static bool isEquality(Predicate P) {
1215     return P == ICMP_EQ || P == ICMP_NE;
1216   }
1217 
1218   /// Return true if this predicate is either EQ or NE.  This also
1219   /// tests for commutativity.
1220   bool isEquality() const {
1221     return isEquality(getPredicate());
1222   }
1223 
1224   /// @returns true if the predicate of this ICmpInst is commutative
1225   /// Determine if this relation is commutative.
1226   bool isCommutative() const { return isEquality(); }
1227 
1228   /// Return true if the predicate is relational (not EQ or NE).
1229   ///
1230   bool isRelational() const {
1231     return !isEquality();
1232   }
1233 
1234   /// Return true if the predicate is relational (not EQ or NE).
1235   ///
1236   static bool isRelational(Predicate P) {
1237     return !isEquality(P);
1238   }
1239 
1240   /// Return true if the predicate is SGT or UGT.
1241   ///
1242   static bool isGT(Predicate P) {
1243     return P == ICMP_SGT || P == ICMP_UGT;
1244   }
1245 
1246   /// Return true if the predicate is SLT or ULT.
1247   ///
1248   static bool isLT(Predicate P) {
1249     return P == ICMP_SLT || P == ICMP_ULT;
1250   }
1251 
1252   /// Return true if the predicate is SGE or UGE.
1253   ///
1254   static bool isGE(Predicate P) {
1255     return P == ICMP_SGE || P == ICMP_UGE;
1256   }
1257 
1258   /// Return true if the predicate is SLE or ULE.
1259   ///
1260   static bool isLE(Predicate P) {
1261     return P == ICMP_SLE || P == ICMP_ULE;
1262   }
1263 
1264   /// Returns the sequence of all ICmp predicates.
1265   ///
1266   static auto predicates() { return ICmpPredicates(); }
1267 
1268   /// Exchange the two operands to this instruction in such a way that it does
1269   /// not modify the semantics of the instruction. The predicate value may be
1270   /// changed to retain the same result if the predicate is order dependent
1271   /// (e.g. ult).
1272   /// Swap operands and adjust predicate.
1273   void swapOperands() {
1274     setPredicate(getSwappedPredicate());
1275     Op<0>().swap(Op<1>());
1276   }
1277 
1278   /// Return result of `LHS Pred RHS` comparison.
1279   static bool compare(const APInt &LHS, const APInt &RHS,
1280                       ICmpInst::Predicate Pred);
1281 
1282   // Methods for support type inquiry through isa, cast, and dyn_cast:
1283   static bool classof(const Instruction *I) {
1284     return I->getOpcode() == Instruction::ICmp;
1285   }
1286   static bool classof(const Value *V) {
1287     return isa<Instruction>(V) && classof(cast<Instruction>(V));
1288   }
1289 };
1290 
1291 //===----------------------------------------------------------------------===//
1292 //                               FCmpInst Class
1293 //===----------------------------------------------------------------------===//
1294 
1295 /// This instruction compares its operands according to the predicate given
1296 /// to the constructor. It only operates on floating point values or packed
1297 /// vectors of floating point values. The operands must be identical types.
1298 /// Represents a floating point comparison operator.
1299 class FCmpInst: public CmpInst {
1300   void AssertOK() {
1301     assert(isFPPredicate() && "Invalid FCmp predicate value");
1302     assert(getOperand(0)->getType() == getOperand(1)->getType() &&
1303            "Both operands to FCmp instruction are not of the same type!");
1304     // Check that the operands are the right type
1305     assert(getOperand(0)->getType()->isFPOrFPVectorTy() &&
1306            "Invalid operand types for FCmp instruction");
1307   }
1308 
1309 protected:
1310   // Note: Instruction needs to be a friend here to call cloneImpl.
1311   friend class Instruction;
1312 
1313   /// Clone an identical FCmpInst
1314   FCmpInst *cloneImpl() const;
1315 
1316 public:
1317   /// Constructor with insertion semantics.
1318   FCmpInst(InsertPosition InsertBefore, ///< Where to insert
1319            Predicate pred, ///< The predicate to use for the comparison
1320            Value *LHS,     ///< The left-hand-side of the expression
1321            Value *RHS,     ///< The right-hand-side of the expression
1322            const Twine &NameStr = "" ///< Name of the instruction
1323            )
1324       : CmpInst(makeCmpResultType(LHS->getType()), Instruction::FCmp, pred, LHS,
1325                 RHS, NameStr, InsertBefore) {
1326     AssertOK();
1327   }
1328 
1329   /// Constructor with no-insertion semantics
1330   FCmpInst(Predicate Pred, ///< The predicate to use for the comparison
1331            Value *LHS,     ///< The left-hand-side of the expression
1332            Value *RHS,     ///< The right-hand-side of the expression
1333            const Twine &NameStr = "", ///< Name of the instruction
1334            Instruction *FlagsSource = nullptr)
1335       : CmpInst(makeCmpResultType(LHS->getType()), Instruction::FCmp, Pred, LHS,
1336                 RHS, NameStr, nullptr, FlagsSource) {
1337     AssertOK();
1338   }
1339 
1340   /// @returns true if the predicate of this instruction is EQ or NE.
1341   /// Determine if this is an equality predicate.
1342   static bool isEquality(Predicate Pred) {
1343     return Pred == FCMP_OEQ || Pred == FCMP_ONE || Pred == FCMP_UEQ ||
1344            Pred == FCMP_UNE;
1345   }
1346 
1347   /// @returns true if the predicate of this instruction is EQ or NE.
1348   /// Determine if this is an equality predicate.
1349   bool isEquality() const { return isEquality(getPredicate()); }
1350 
1351   /// @returns true if the predicate of this instruction is commutative.
1352   /// Determine if this is a commutative predicate.
1353   bool isCommutative() const {
1354     return isEquality() ||
1355            getPredicate() == FCMP_FALSE ||
1356            getPredicate() == FCMP_TRUE ||
1357            getPredicate() == FCMP_ORD ||
1358            getPredicate() == FCMP_UNO;
1359   }
1360 
1361   /// @returns true if the predicate is relational (not EQ or NE).
1362   /// Determine if this a relational predicate.
1363   bool isRelational() const { return !isEquality(); }
1364 
1365   /// Exchange the two operands to this instruction in such a way that it does
1366   /// not modify the semantics of the instruction. The predicate value may be
1367   /// changed to retain the same result if the predicate is order dependent
1368   /// (e.g. ult).
1369   /// Swap operands and adjust predicate.
1370   void swapOperands() {
1371     setPredicate(getSwappedPredicate());
1372     Op<0>().swap(Op<1>());
1373   }
1374 
1375   /// Returns the sequence of all FCmp predicates.
1376   ///
1377   static auto predicates() { return FCmpPredicates(); }
1378 
1379   /// Return result of `LHS Pred RHS` comparison.
1380   static bool compare(const APFloat &LHS, const APFloat &RHS,
1381                       FCmpInst::Predicate Pred);
1382 
1383   /// Methods for support type inquiry through isa, cast, and dyn_cast:
1384   static bool classof(const Instruction *I) {
1385     return I->getOpcode() == Instruction::FCmp;
1386   }
1387   static bool classof(const Value *V) {
1388     return isa<Instruction>(V) && classof(cast<Instruction>(V));
1389   }
1390 };
1391 
1392 //===----------------------------------------------------------------------===//
1393 /// This class represents a function call, abstracting a target
1394 /// machine's calling convention.  This class uses low bit of the SubClassData
1395 /// field to indicate whether or not this is a tail call.  The rest of the bits
1396 /// hold the calling convention of the call.
1397 ///
1398 class CallInst : public CallBase {
1399   CallInst(const CallInst &CI);
1400 
1401   /// Construct a CallInst from a range of arguments
1402   inline CallInst(FunctionType *Ty, Value *Func, ArrayRef<Value *> Args,
1403                   ArrayRef<OperandBundleDef> Bundles, const Twine &NameStr,
1404                   InsertPosition InsertBefore);
1405 
1406   inline CallInst(FunctionType *Ty, Value *Func, ArrayRef<Value *> Args,
1407                   const Twine &NameStr, InsertPosition InsertBefore)
1408       : CallInst(Ty, Func, Args, std::nullopt, NameStr, InsertBefore) {}
1409 
1410   explicit CallInst(FunctionType *Ty, Value *F, const Twine &NameStr,
1411                     InsertPosition InsertBefore);
1412 
1413   void init(FunctionType *FTy, Value *Func, ArrayRef<Value *> Args,
1414             ArrayRef<OperandBundleDef> Bundles, const Twine &NameStr);
1415   void init(FunctionType *FTy, Value *Func, const Twine &NameStr);
1416 
1417   /// Compute the number of operands to allocate.
1418   static int ComputeNumOperands(int NumArgs, int NumBundleInputs = 0) {
1419     // We need one operand for the called function, plus the input operand
1420     // counts provided.
1421     return 1 + NumArgs + NumBundleInputs;
1422   }
1423 
1424 protected:
1425   // Note: Instruction needs to be a friend here to call cloneImpl.
1426   friend class Instruction;
1427 
1428   CallInst *cloneImpl() const;
1429 
1430 public:
1431   static CallInst *Create(FunctionType *Ty, Value *F, const Twine &NameStr = "",
1432                           InsertPosition InsertBefore = nullptr) {
1433     return new (ComputeNumOperands(0)) CallInst(Ty, F, NameStr, InsertBefore);
1434   }
1435 
1436   static CallInst *Create(FunctionType *Ty, Value *Func, ArrayRef<Value *> Args,
1437                           const Twine &NameStr,
1438                           InsertPosition InsertBefore = nullptr) {
1439     return new (ComputeNumOperands(Args.size()))
1440         CallInst(Ty, Func, Args, std::nullopt, NameStr, InsertBefore);
1441   }
1442 
1443   static CallInst *Create(FunctionType *Ty, Value *Func, ArrayRef<Value *> Args,
1444                           ArrayRef<OperandBundleDef> Bundles = std::nullopt,
1445                           const Twine &NameStr = "",
1446                           InsertPosition InsertBefore = nullptr) {
1447     const int NumOperands =
1448         ComputeNumOperands(Args.size(), CountBundleInputs(Bundles));
1449     const unsigned DescriptorBytes = Bundles.size() * sizeof(BundleOpInfo);
1450 
1451     return new (NumOperands, DescriptorBytes)
1452         CallInst(Ty, Func, Args, Bundles, NameStr, InsertBefore);
1453   }
1454 
1455   static CallInst *Create(FunctionCallee Func, const Twine &NameStr = "",
1456                           InsertPosition InsertBefore = nullptr) {
1457     return Create(Func.getFunctionType(), Func.getCallee(), NameStr,
1458                   InsertBefore);
1459   }
1460 
1461   static CallInst *Create(FunctionCallee Func, ArrayRef<Value *> Args,
1462                           ArrayRef<OperandBundleDef> Bundles = std::nullopt,
1463                           const Twine &NameStr = "",
1464                           InsertPosition InsertBefore = nullptr) {
1465     return Create(Func.getFunctionType(), Func.getCallee(), Args, Bundles,
1466                   NameStr, InsertBefore);
1467   }
1468 
1469   static CallInst *Create(FunctionCallee Func, ArrayRef<Value *> Args,
1470                           const Twine &NameStr,
1471                           InsertPosition InsertBefore = nullptr) {
1472     return Create(Func.getFunctionType(), Func.getCallee(), Args, NameStr,
1473                   InsertBefore);
1474   }
1475 
1476   /// Create a clone of \p CI with a different set of operand bundles and
1477   /// insert it before \p InsertBefore.
1478   ///
1479   /// The returned call instruction is identical \p CI in every way except that
1480   /// the operand bundles for the new instruction are set to the operand bundles
1481   /// in \p Bundles.
1482   static CallInst *Create(CallInst *CI, ArrayRef<OperandBundleDef> Bundles,
1483                           InsertPosition InsertPt = nullptr);
1484 
1485   // Note that 'musttail' implies 'tail'.
1486   enum TailCallKind : unsigned {
1487     TCK_None = 0,
1488     TCK_Tail = 1,
1489     TCK_MustTail = 2,
1490     TCK_NoTail = 3,
1491     TCK_LAST = TCK_NoTail
1492   };
1493 
1494   using TailCallKindField = Bitfield::Element<TailCallKind, 0, 2, TCK_LAST>;
1495   static_assert(
1496       Bitfield::areContiguous<TailCallKindField, CallBase::CallingConvField>(),
1497       "Bitfields must be contiguous");
1498 
1499   TailCallKind getTailCallKind() const {
1500     return getSubclassData<TailCallKindField>();
1501   }
1502 
1503   bool isTailCall() const {
1504     TailCallKind Kind = getTailCallKind();
1505     return Kind == TCK_Tail || Kind == TCK_MustTail;
1506   }
1507 
1508   bool isMustTailCall() const { return getTailCallKind() == TCK_MustTail; }
1509 
1510   bool isNoTailCall() const { return getTailCallKind() == TCK_NoTail; }
1511 
1512   void setTailCallKind(TailCallKind TCK) {
1513     setSubclassData<TailCallKindField>(TCK);
1514   }
1515 
1516   void setTailCall(bool IsTc = true) {
1517     setTailCallKind(IsTc ? TCK_Tail : TCK_None);
1518   }
1519 
1520   /// Return true if the call can return twice
1521   bool canReturnTwice() const { return hasFnAttr(Attribute::ReturnsTwice); }
1522   void setCanReturnTwice() { addFnAttr(Attribute::ReturnsTwice); }
1523 
1524   /// Return true if the call is for a noreturn trap intrinsic.
1525   bool isNonContinuableTrap() const {
1526     switch (getIntrinsicID()) {
1527     case Intrinsic::trap:
1528     case Intrinsic::ubsantrap:
1529       return !hasFnAttr("trap-func-name");
1530     default:
1531       return false;
1532     }
1533   }
1534 
1535   // Methods for support type inquiry through isa, cast, and dyn_cast:
1536   static bool classof(const Instruction *I) {
1537     return I->getOpcode() == Instruction::Call;
1538   }
1539   static bool classof(const Value *V) {
1540     return isa<Instruction>(V) && classof(cast<Instruction>(V));
1541   }
1542 
1543   /// Updates profile metadata by scaling it by \p S / \p T.
1544   void updateProfWeight(uint64_t S, uint64_t T);
1545 
1546 private:
1547   // Shadow Instruction::setInstructionSubclassData with a private forwarding
1548   // method so that subclasses cannot accidentally use it.
1549   template <typename Bitfield>
1550   void setSubclassData(typename Bitfield::Type Value) {
1551     Instruction::setSubclassData<Bitfield>(Value);
1552   }
1553 };
1554 
1555 CallInst::CallInst(FunctionType *Ty, Value *Func, ArrayRef<Value *> Args,
1556                    ArrayRef<OperandBundleDef> Bundles, const Twine &NameStr,
1557                    InsertPosition InsertBefore)
1558     : CallBase(Ty->getReturnType(), Instruction::Call,
1559                OperandTraits<CallBase>::op_end(this) -
1560                    (Args.size() + CountBundleInputs(Bundles) + 1),
1561                unsigned(Args.size() + CountBundleInputs(Bundles) + 1),
1562                InsertBefore) {
1563   init(Ty, Func, Args, Bundles, NameStr);
1564 }
1565 
1566 //===----------------------------------------------------------------------===//
1567 //                               SelectInst Class
1568 //===----------------------------------------------------------------------===//
1569 
1570 /// This class represents the LLVM 'select' instruction.
1571 ///
1572 class SelectInst : public Instruction {
1573 
1574   SelectInst(Value *C, Value *S1, Value *S2, const Twine &NameStr,
1575              InsertPosition InsertBefore)
1576       : Instruction(S1->getType(), Instruction::Select, &Op<0>(), 3,
1577                     InsertBefore) {
1578     init(C, S1, S2);
1579     setName(NameStr);
1580   }
1581 
1582   void init(Value *C, Value *S1, Value *S2) {
1583     assert(!areInvalidOperands(C, S1, S2) && "Invalid operands for select");
1584     Op<0>() = C;
1585     Op<1>() = S1;
1586     Op<2>() = S2;
1587   }
1588 
1589 protected:
1590   // Note: Instruction needs to be a friend here to call cloneImpl.
1591   friend class Instruction;
1592 
1593   SelectInst *cloneImpl() const;
1594 
1595 public:
1596   static SelectInst *Create(Value *C, Value *S1, Value *S2,
1597                             const Twine &NameStr = "",
1598                             InsertPosition InsertBefore = nullptr,
1599                             Instruction *MDFrom = nullptr) {
1600     SelectInst *Sel = new(3) SelectInst(C, S1, S2, NameStr, InsertBefore);
1601     if (MDFrom)
1602       Sel->copyMetadata(*MDFrom);
1603     return Sel;
1604   }
1605 
1606   const Value *getCondition() const { return Op<0>(); }
1607   const Value *getTrueValue() const { return Op<1>(); }
1608   const Value *getFalseValue() const { return Op<2>(); }
1609   Value *getCondition() { return Op<0>(); }
1610   Value *getTrueValue() { return Op<1>(); }
1611   Value *getFalseValue() { return Op<2>(); }
1612 
1613   void setCondition(Value *V) { Op<0>() = V; }
1614   void setTrueValue(Value *V) { Op<1>() = V; }
1615   void setFalseValue(Value *V) { Op<2>() = V; }
1616 
1617   /// Swap the true and false values of the select instruction.
1618   /// This doesn't swap prof metadata.
1619   void swapValues() { Op<1>().swap(Op<2>()); }
1620 
1621   /// Return a string if the specified operands are invalid
1622   /// for a select operation, otherwise return null.
1623   static const char *areInvalidOperands(Value *Cond, Value *True, Value *False);
1624 
1625   /// Transparently provide more efficient getOperand methods.
1626   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
1627 
1628   OtherOps getOpcode() const {
1629     return static_cast<OtherOps>(Instruction::getOpcode());
1630   }
1631 
1632   // Methods for support type inquiry through isa, cast, and dyn_cast:
1633   static bool classof(const Instruction *I) {
1634     return I->getOpcode() == Instruction::Select;
1635   }
1636   static bool classof(const Value *V) {
1637     return isa<Instruction>(V) && classof(cast<Instruction>(V));
1638   }
1639 };
1640 
1641 template <>
1642 struct OperandTraits<SelectInst> : public FixedNumOperandTraits<SelectInst, 3> {
1643 };
1644 
1645 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(SelectInst, Value)
1646 
1647 //===----------------------------------------------------------------------===//
1648 //                                VAArgInst Class
1649 //===----------------------------------------------------------------------===//
1650 
1651 /// This class represents the va_arg llvm instruction, which returns
1652 /// an argument of the specified type given a va_list and increments that list
1653 ///
1654 class VAArgInst : public UnaryInstruction {
1655 protected:
1656   // Note: Instruction needs to be a friend here to call cloneImpl.
1657   friend class Instruction;
1658 
1659   VAArgInst *cloneImpl() const;
1660 
1661 public:
1662   VAArgInst(Value *List, Type *Ty, const Twine &NameStr = "",
1663             InsertPosition InsertBefore = nullptr)
1664       : UnaryInstruction(Ty, VAArg, List, InsertBefore) {
1665     setName(NameStr);
1666   }
1667 
1668   Value *getPointerOperand() { return getOperand(0); }
1669   const Value *getPointerOperand() const { return getOperand(0); }
1670   static unsigned getPointerOperandIndex() { return 0U; }
1671 
1672   // Methods for support type inquiry through isa, cast, and dyn_cast:
1673   static bool classof(const Instruction *I) {
1674     return I->getOpcode() == VAArg;
1675   }
1676   static bool classof(const Value *V) {
1677     return isa<Instruction>(V) && classof(cast<Instruction>(V));
1678   }
1679 };
1680 
1681 //===----------------------------------------------------------------------===//
1682 //                                ExtractElementInst Class
1683 //===----------------------------------------------------------------------===//
1684 
1685 /// This instruction extracts a single (scalar)
1686 /// element from a VectorType value
1687 ///
1688 class ExtractElementInst : public Instruction {
1689   ExtractElementInst(Value *Vec, Value *Idx, const Twine &NameStr = "",
1690                      InsertPosition InsertBefore = nullptr);
1691 
1692 protected:
1693   // Note: Instruction needs to be a friend here to call cloneImpl.
1694   friend class Instruction;
1695 
1696   ExtractElementInst *cloneImpl() const;
1697 
1698 public:
1699   static ExtractElementInst *Create(Value *Vec, Value *Idx,
1700                                     const Twine &NameStr = "",
1701                                     InsertPosition InsertBefore = nullptr) {
1702     return new(2) ExtractElementInst(Vec, Idx, NameStr, InsertBefore);
1703   }
1704 
1705   /// Return true if an extractelement instruction can be
1706   /// formed with the specified operands.
1707   static bool isValidOperands(const Value *Vec, const Value *Idx);
1708 
1709   Value *getVectorOperand() { return Op<0>(); }
1710   Value *getIndexOperand() { return Op<1>(); }
1711   const Value *getVectorOperand() const { return Op<0>(); }
1712   const Value *getIndexOperand() const { return Op<1>(); }
1713 
1714   VectorType *getVectorOperandType() const {
1715     return cast<VectorType>(getVectorOperand()->getType());
1716   }
1717 
1718   /// Transparently provide more efficient getOperand methods.
1719   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
1720 
1721   // Methods for support type inquiry through isa, cast, and dyn_cast:
1722   static bool classof(const Instruction *I) {
1723     return I->getOpcode() == Instruction::ExtractElement;
1724   }
1725   static bool classof(const Value *V) {
1726     return isa<Instruction>(V) && classof(cast<Instruction>(V));
1727   }
1728 };
1729 
1730 template <>
1731 struct OperandTraits<ExtractElementInst> :
1732   public FixedNumOperandTraits<ExtractElementInst, 2> {
1733 };
1734 
1735 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(ExtractElementInst, Value)
1736 
1737 //===----------------------------------------------------------------------===//
1738 //                                InsertElementInst Class
1739 //===----------------------------------------------------------------------===//
1740 
1741 /// This instruction inserts a single (scalar)
1742 /// element into a VectorType value
1743 ///
1744 class InsertElementInst : public Instruction {
1745   InsertElementInst(Value *Vec, Value *NewElt, Value *Idx,
1746                     const Twine &NameStr = "",
1747                     InsertPosition InsertBefore = nullptr);
1748 
1749 protected:
1750   // Note: Instruction needs to be a friend here to call cloneImpl.
1751   friend class Instruction;
1752 
1753   InsertElementInst *cloneImpl() const;
1754 
1755 public:
1756   static InsertElementInst *Create(Value *Vec, Value *NewElt, Value *Idx,
1757                                    const Twine &NameStr = "",
1758                                    InsertPosition InsertBefore = nullptr) {
1759     return new(3) InsertElementInst(Vec, NewElt, Idx, NameStr, InsertBefore);
1760   }
1761 
1762   /// Return true if an insertelement instruction can be
1763   /// formed with the specified operands.
1764   static bool isValidOperands(const Value *Vec, const Value *NewElt,
1765                               const Value *Idx);
1766 
1767   /// Overload to return most specific vector type.
1768   ///
1769   VectorType *getType() const {
1770     return cast<VectorType>(Instruction::getType());
1771   }
1772 
1773   /// Transparently provide more efficient getOperand methods.
1774   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
1775 
1776   // Methods for support type inquiry through isa, cast, and dyn_cast:
1777   static bool classof(const Instruction *I) {
1778     return I->getOpcode() == Instruction::InsertElement;
1779   }
1780   static bool classof(const Value *V) {
1781     return isa<Instruction>(V) && classof(cast<Instruction>(V));
1782   }
1783 };
1784 
1785 template <>
1786 struct OperandTraits<InsertElementInst> :
1787   public FixedNumOperandTraits<InsertElementInst, 3> {
1788 };
1789 
1790 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(InsertElementInst, Value)
1791 
1792 //===----------------------------------------------------------------------===//
1793 //                           ShuffleVectorInst Class
1794 //===----------------------------------------------------------------------===//
1795 
1796 constexpr int PoisonMaskElem = -1;
1797 
1798 /// This instruction constructs a fixed permutation of two
1799 /// input vectors.
1800 ///
1801 /// For each element of the result vector, the shuffle mask selects an element
1802 /// from one of the input vectors to copy to the result. Non-negative elements
1803 /// in the mask represent an index into the concatenated pair of input vectors.
1804 /// PoisonMaskElem (-1) specifies that the result element is poison.
1805 ///
1806 /// For scalable vectors, all the elements of the mask must be 0 or -1. This
1807 /// requirement may be relaxed in the future.
1808 class ShuffleVectorInst : public Instruction {
1809   SmallVector<int, 4> ShuffleMask;
1810   Constant *ShuffleMaskForBitcode;
1811 
1812 protected:
1813   // Note: Instruction needs to be a friend here to call cloneImpl.
1814   friend class Instruction;
1815 
1816   ShuffleVectorInst *cloneImpl() const;
1817 
1818 public:
1819   ShuffleVectorInst(Value *V1, Value *Mask, const Twine &NameStr = "",
1820                     InsertPosition InsertBefore = nullptr);
1821   ShuffleVectorInst(Value *V1, ArrayRef<int> Mask, const Twine &NameStr = "",
1822                     InsertPosition InsertBefore = nullptr);
1823   ShuffleVectorInst(Value *V1, Value *V2, Value *Mask,
1824                     const Twine &NameStr = "",
1825                     InsertPosition InsertBefore = nullptr);
1826   ShuffleVectorInst(Value *V1, Value *V2, ArrayRef<int> Mask,
1827                     const Twine &NameStr = "",
1828                     InsertPosition InsertBefore = nullptr);
1829 
1830   void *operator new(size_t S) { return User::operator new(S, 2); }
1831   void operator delete(void *Ptr) { return User::operator delete(Ptr); }
1832 
1833   /// Swap the operands and adjust the mask to preserve the semantics
1834   /// of the instruction.
1835   void commute();
1836 
1837   /// Return true if a shufflevector instruction can be
1838   /// formed with the specified operands.
1839   static bool isValidOperands(const Value *V1, const Value *V2,
1840                               const Value *Mask);
1841   static bool isValidOperands(const Value *V1, const Value *V2,
1842                               ArrayRef<int> Mask);
1843 
1844   /// Overload to return most specific vector type.
1845   ///
1846   VectorType *getType() const {
1847     return cast<VectorType>(Instruction::getType());
1848   }
1849 
1850   /// Transparently provide more efficient getOperand methods.
1851   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
1852 
1853   /// Return the shuffle mask value of this instruction for the given element
1854   /// index. Return PoisonMaskElem if the element is undef.
1855   int getMaskValue(unsigned Elt) const { return ShuffleMask[Elt]; }
1856 
1857   /// Convert the input shuffle mask operand to a vector of integers. Undefined
1858   /// elements of the mask are returned as PoisonMaskElem.
1859   static void getShuffleMask(const Constant *Mask,
1860                              SmallVectorImpl<int> &Result);
1861 
1862   /// Return the mask for this instruction as a vector of integers. Undefined
1863   /// elements of the mask are returned as PoisonMaskElem.
1864   void getShuffleMask(SmallVectorImpl<int> &Result) const {
1865     Result.assign(ShuffleMask.begin(), ShuffleMask.end());
1866   }
1867 
1868   /// Return the mask for this instruction, for use in bitcode.
1869   ///
1870   /// TODO: This is temporary until we decide a new bitcode encoding for
1871   /// shufflevector.
1872   Constant *getShuffleMaskForBitcode() const { return ShuffleMaskForBitcode; }
1873 
1874   static Constant *convertShuffleMaskForBitcode(ArrayRef<int> Mask,
1875                                                 Type *ResultTy);
1876 
1877   void setShuffleMask(ArrayRef<int> Mask);
1878 
1879   ArrayRef<int> getShuffleMask() const { return ShuffleMask; }
1880 
1881   /// Return true if this shuffle returns a vector with a different number of
1882   /// elements than its source vectors.
1883   /// Examples: shufflevector <4 x n> A, <4 x n> B, <1,2,3>
1884   ///           shufflevector <4 x n> A, <4 x n> B, <1,2,3,4,5>
1885   bool changesLength() const {
1886     unsigned NumSourceElts = cast<VectorType>(Op<0>()->getType())
1887                                  ->getElementCount()
1888                                  .getKnownMinValue();
1889     unsigned NumMaskElts = ShuffleMask.size();
1890     return NumSourceElts != NumMaskElts;
1891   }
1892 
1893   /// Return true if this shuffle returns a vector with a greater number of
1894   /// elements than its source vectors.
1895   /// Example: shufflevector <2 x n> A, <2 x n> B, <1,2,3>
1896   bool increasesLength() const {
1897     unsigned NumSourceElts = cast<VectorType>(Op<0>()->getType())
1898                                  ->getElementCount()
1899                                  .getKnownMinValue();
1900     unsigned NumMaskElts = ShuffleMask.size();
1901     return NumSourceElts < NumMaskElts;
1902   }
1903 
1904   /// Return true if this shuffle mask chooses elements from exactly one source
1905   /// vector.
1906   /// Example: <7,5,undef,7>
1907   /// This assumes that vector operands (of length \p NumSrcElts) are the same
1908   /// length as the mask.
1909   static bool isSingleSourceMask(ArrayRef<int> Mask, int NumSrcElts);
1910   static bool isSingleSourceMask(const Constant *Mask, int NumSrcElts) {
1911     assert(Mask->getType()->isVectorTy() && "Shuffle needs vector constant.");
1912     SmallVector<int, 16> MaskAsInts;
1913     getShuffleMask(Mask, MaskAsInts);
1914     return isSingleSourceMask(MaskAsInts, NumSrcElts);
1915   }
1916 
1917   /// Return true if this shuffle chooses elements from exactly one source
1918   /// vector without changing the length of that vector.
1919   /// Example: shufflevector <4 x n> A, <4 x n> B, <3,0,undef,3>
1920   /// TODO: Optionally allow length-changing shuffles.
1921   bool isSingleSource() const {
1922     return !changesLength() &&
1923            isSingleSourceMask(ShuffleMask, ShuffleMask.size());
1924   }
1925 
1926   /// Return true if this shuffle mask chooses elements from exactly one source
1927   /// vector without lane crossings. A shuffle using this mask is not
1928   /// necessarily a no-op because it may change the number of elements from its
1929   /// input vectors or it may provide demanded bits knowledge via undef lanes.
1930   /// Example: <undef,undef,2,3>
1931   static bool isIdentityMask(ArrayRef<int> Mask, int NumSrcElts);
1932   static bool isIdentityMask(const Constant *Mask, int NumSrcElts) {
1933     assert(Mask->getType()->isVectorTy() && "Shuffle needs vector constant.");
1934 
1935     // Not possible to express a shuffle mask for a scalable vector for this
1936     // case.
1937     if (isa<ScalableVectorType>(Mask->getType()))
1938       return false;
1939 
1940     SmallVector<int, 16> MaskAsInts;
1941     getShuffleMask(Mask, MaskAsInts);
1942     return isIdentityMask(MaskAsInts, NumSrcElts);
1943   }
1944 
1945   /// Return true if this shuffle chooses elements from exactly one source
1946   /// vector without lane crossings and does not change the number of elements
1947   /// from its input vectors.
1948   /// Example: shufflevector <4 x n> A, <4 x n> B, <4,undef,6,undef>
1949   bool isIdentity() const {
1950     // Not possible to express a shuffle mask for a scalable vector for this
1951     // case.
1952     if (isa<ScalableVectorType>(getType()))
1953       return false;
1954 
1955     return !changesLength() && isIdentityMask(ShuffleMask, ShuffleMask.size());
1956   }
1957 
1958   /// Return true if this shuffle lengthens exactly one source vector with
1959   /// undefs in the high elements.
1960   bool isIdentityWithPadding() const;
1961 
1962   /// Return true if this shuffle extracts the first N elements of exactly one
1963   /// source vector.
1964   bool isIdentityWithExtract() const;
1965 
1966   /// Return true if this shuffle concatenates its 2 source vectors. This
1967   /// returns false if either input is undefined. In that case, the shuffle is
1968   /// is better classified as an identity with padding operation.
1969   bool isConcat() const;
1970 
1971   /// Return true if this shuffle mask chooses elements from its source vectors
1972   /// without lane crossings. A shuffle using this mask would be
1973   /// equivalent to a vector select with a constant condition operand.
1974   /// Example: <4,1,6,undef>
1975   /// This returns false if the mask does not choose from both input vectors.
1976   /// In that case, the shuffle is better classified as an identity shuffle.
1977   /// This assumes that vector operands are the same length as the mask
1978   /// (a length-changing shuffle can never be equivalent to a vector select).
1979   static bool isSelectMask(ArrayRef<int> Mask, int NumSrcElts);
1980   static bool isSelectMask(const Constant *Mask, int NumSrcElts) {
1981     assert(Mask->getType()->isVectorTy() && "Shuffle needs vector constant.");
1982     SmallVector<int, 16> MaskAsInts;
1983     getShuffleMask(Mask, MaskAsInts);
1984     return isSelectMask(MaskAsInts, NumSrcElts);
1985   }
1986 
1987   /// Return true if this shuffle chooses elements from its source vectors
1988   /// without lane crossings and all operands have the same number of elements.
1989   /// In other words, this shuffle is equivalent to a vector select with a
1990   /// constant condition operand.
1991   /// Example: shufflevector <4 x n> A, <4 x n> B, <undef,1,6,3>
1992   /// This returns false if the mask does not choose from both input vectors.
1993   /// In that case, the shuffle is better classified as an identity shuffle.
1994   /// TODO: Optionally allow length-changing shuffles.
1995   bool isSelect() const {
1996     return !changesLength() && isSelectMask(ShuffleMask, ShuffleMask.size());
1997   }
1998 
1999   /// Return true if this shuffle mask swaps the order of elements from exactly
2000   /// one source vector.
2001   /// Example: <7,6,undef,4>
2002   /// This assumes that vector operands (of length \p NumSrcElts) are the same
2003   /// length as the mask.
2004   static bool isReverseMask(ArrayRef<int> Mask, int NumSrcElts);
2005   static bool isReverseMask(const Constant *Mask, int NumSrcElts) {
2006     assert(Mask->getType()->isVectorTy() && "Shuffle needs vector constant.");
2007     SmallVector<int, 16> MaskAsInts;
2008     getShuffleMask(Mask, MaskAsInts);
2009     return isReverseMask(MaskAsInts, NumSrcElts);
2010   }
2011 
2012   /// Return true if this shuffle swaps the order of elements from exactly
2013   /// one source vector.
2014   /// Example: shufflevector <4 x n> A, <4 x n> B, <3,undef,1,undef>
2015   /// TODO: Optionally allow length-changing shuffles.
2016   bool isReverse() const {
2017     return !changesLength() && isReverseMask(ShuffleMask, ShuffleMask.size());
2018   }
2019 
2020   /// Return true if this shuffle mask chooses all elements with the same value
2021   /// as the first element of exactly one source vector.
2022   /// Example: <4,undef,undef,4>
2023   /// This assumes that vector operands (of length \p NumSrcElts) are the same
2024   /// length as the mask.
2025   static bool isZeroEltSplatMask(ArrayRef<int> Mask, int NumSrcElts);
2026   static bool isZeroEltSplatMask(const Constant *Mask, int NumSrcElts) {
2027     assert(Mask->getType()->isVectorTy() && "Shuffle needs vector constant.");
2028     SmallVector<int, 16> MaskAsInts;
2029     getShuffleMask(Mask, MaskAsInts);
2030     return isZeroEltSplatMask(MaskAsInts, NumSrcElts);
2031   }
2032 
2033   /// Return true if all elements of this shuffle are the same value as the
2034   /// first element of exactly one source vector without changing the length
2035   /// of that vector.
2036   /// Example: shufflevector <4 x n> A, <4 x n> B, <undef,0,undef,0>
2037   /// TODO: Optionally allow length-changing shuffles.
2038   /// TODO: Optionally allow splats from other elements.
2039   bool isZeroEltSplat() const {
2040     return !changesLength() &&
2041            isZeroEltSplatMask(ShuffleMask, ShuffleMask.size());
2042   }
2043 
2044   /// Return true if this shuffle mask is a transpose mask.
2045   /// Transpose vector masks transpose a 2xn matrix. They read corresponding
2046   /// even- or odd-numbered vector elements from two n-dimensional source
2047   /// vectors and write each result into consecutive elements of an
2048   /// n-dimensional destination vector. Two shuffles are necessary to complete
2049   /// the transpose, one for the even elements and another for the odd elements.
2050   /// This description closely follows how the TRN1 and TRN2 AArch64
2051   /// instructions operate.
2052   ///
2053   /// For example, a simple 2x2 matrix can be transposed with:
2054   ///
2055   ///   ; Original matrix
2056   ///   m0 = < a, b >
2057   ///   m1 = < c, d >
2058   ///
2059   ///   ; Transposed matrix
2060   ///   t0 = < a, c > = shufflevector m0, m1, < 0, 2 >
2061   ///   t1 = < b, d > = shufflevector m0, m1, < 1, 3 >
2062   ///
2063   /// For matrices having greater than n columns, the resulting nx2 transposed
2064   /// matrix is stored in two result vectors such that one vector contains
2065   /// interleaved elements from all the even-numbered rows and the other vector
2066   /// contains interleaved elements from all the odd-numbered rows. For example,
2067   /// a 2x4 matrix can be transposed with:
2068   ///
2069   ///   ; Original matrix
2070   ///   m0 = < a, b, c, d >
2071   ///   m1 = < e, f, g, h >
2072   ///
2073   ///   ; Transposed matrix
2074   ///   t0 = < a, e, c, g > = shufflevector m0, m1 < 0, 4, 2, 6 >
2075   ///   t1 = < b, f, d, h > = shufflevector m0, m1 < 1, 5, 3, 7 >
2076   static bool isTransposeMask(ArrayRef<int> Mask, int NumSrcElts);
2077   static bool isTransposeMask(const Constant *Mask, int NumSrcElts) {
2078     assert(Mask->getType()->isVectorTy() && "Shuffle needs vector constant.");
2079     SmallVector<int, 16> MaskAsInts;
2080     getShuffleMask(Mask, MaskAsInts);
2081     return isTransposeMask(MaskAsInts, NumSrcElts);
2082   }
2083 
2084   /// Return true if this shuffle transposes the elements of its inputs without
2085   /// changing the length of the vectors. This operation may also be known as a
2086   /// merge or interleave. See the description for isTransposeMask() for the
2087   /// exact specification.
2088   /// Example: shufflevector <4 x n> A, <4 x n> B, <0,4,2,6>
2089   bool isTranspose() const {
2090     return !changesLength() && isTransposeMask(ShuffleMask, ShuffleMask.size());
2091   }
2092 
2093   /// Return true if this shuffle mask is a splice mask, concatenating the two
2094   /// inputs together and then extracts an original width vector starting from
2095   /// the splice index.
2096   /// Example: shufflevector <4 x n> A, <4 x n> B, <1,2,3,4>
2097   /// This assumes that vector operands (of length \p NumSrcElts) are the same
2098   /// length as the mask.
2099   static bool isSpliceMask(ArrayRef<int> Mask, int NumSrcElts, int &Index);
2100   static bool isSpliceMask(const Constant *Mask, int NumSrcElts, int &Index) {
2101     assert(Mask->getType()->isVectorTy() && "Shuffle needs vector constant.");
2102     SmallVector<int, 16> MaskAsInts;
2103     getShuffleMask(Mask, MaskAsInts);
2104     return isSpliceMask(MaskAsInts, NumSrcElts, Index);
2105   }
2106 
2107   /// Return true if this shuffle splices two inputs without changing the length
2108   /// of the vectors. This operation concatenates the two inputs together and
2109   /// then extracts an original width vector starting from the splice index.
2110   /// Example: shufflevector <4 x n> A, <4 x n> B, <1,2,3,4>
2111   bool isSplice(int &Index) const {
2112     return !changesLength() &&
2113            isSpliceMask(ShuffleMask, ShuffleMask.size(), Index);
2114   }
2115 
2116   /// Return true if this shuffle mask is an extract subvector mask.
2117   /// A valid extract subvector mask returns a smaller vector from a single
2118   /// source operand. The base extraction index is returned as well.
2119   static bool isExtractSubvectorMask(ArrayRef<int> Mask, int NumSrcElts,
2120                                      int &Index);
2121   static bool isExtractSubvectorMask(const Constant *Mask, int NumSrcElts,
2122                                      int &Index) {
2123     assert(Mask->getType()->isVectorTy() && "Shuffle needs vector constant.");
2124     // Not possible to express a shuffle mask for a scalable vector for this
2125     // case.
2126     if (isa<ScalableVectorType>(Mask->getType()))
2127       return false;
2128     SmallVector<int, 16> MaskAsInts;
2129     getShuffleMask(Mask, MaskAsInts);
2130     return isExtractSubvectorMask(MaskAsInts, NumSrcElts, Index);
2131   }
2132 
2133   /// Return true if this shuffle mask is an extract subvector mask.
2134   bool isExtractSubvectorMask(int &Index) const {
2135     // Not possible to express a shuffle mask for a scalable vector for this
2136     // case.
2137     if (isa<ScalableVectorType>(getType()))
2138       return false;
2139 
2140     int NumSrcElts =
2141         cast<FixedVectorType>(Op<0>()->getType())->getNumElements();
2142     return isExtractSubvectorMask(ShuffleMask, NumSrcElts, Index);
2143   }
2144 
2145   /// Return true if this shuffle mask is an insert subvector mask.
2146   /// A valid insert subvector mask inserts the lowest elements of a second
2147   /// source operand into an in-place first source operand.
2148   /// Both the sub vector width and the insertion index is returned.
2149   static bool isInsertSubvectorMask(ArrayRef<int> Mask, int NumSrcElts,
2150                                     int &NumSubElts, int &Index);
2151   static bool isInsertSubvectorMask(const Constant *Mask, int NumSrcElts,
2152                                     int &NumSubElts, int &Index) {
2153     assert(Mask->getType()->isVectorTy() && "Shuffle needs vector constant.");
2154     // Not possible to express a shuffle mask for a scalable vector for this
2155     // case.
2156     if (isa<ScalableVectorType>(Mask->getType()))
2157       return false;
2158     SmallVector<int, 16> MaskAsInts;
2159     getShuffleMask(Mask, MaskAsInts);
2160     return isInsertSubvectorMask(MaskAsInts, NumSrcElts, NumSubElts, Index);
2161   }
2162 
2163   /// Return true if this shuffle mask is an insert subvector mask.
2164   bool isInsertSubvectorMask(int &NumSubElts, int &Index) const {
2165     // Not possible to express a shuffle mask for a scalable vector for this
2166     // case.
2167     if (isa<ScalableVectorType>(getType()))
2168       return false;
2169 
2170     int NumSrcElts =
2171         cast<FixedVectorType>(Op<0>()->getType())->getNumElements();
2172     return isInsertSubvectorMask(ShuffleMask, NumSrcElts, NumSubElts, Index);
2173   }
2174 
2175   /// Return true if this shuffle mask replicates each of the \p VF elements
2176   /// in a vector \p ReplicationFactor times.
2177   /// For example, the mask for \p ReplicationFactor=3 and \p VF=4 is:
2178   ///   <0,0,0,1,1,1,2,2,2,3,3,3>
2179   static bool isReplicationMask(ArrayRef<int> Mask, int &ReplicationFactor,
2180                                 int &VF);
2181   static bool isReplicationMask(const Constant *Mask, int &ReplicationFactor,
2182                                 int &VF) {
2183     assert(Mask->getType()->isVectorTy() && "Shuffle needs vector constant.");
2184     // Not possible to express a shuffle mask for a scalable vector for this
2185     // case.
2186     if (isa<ScalableVectorType>(Mask->getType()))
2187       return false;
2188     SmallVector<int, 16> MaskAsInts;
2189     getShuffleMask(Mask, MaskAsInts);
2190     return isReplicationMask(MaskAsInts, ReplicationFactor, VF);
2191   }
2192 
2193   /// Return true if this shuffle mask is a replication mask.
2194   bool isReplicationMask(int &ReplicationFactor, int &VF) const;
2195 
2196   /// Return true if this shuffle mask represents "clustered" mask of size VF,
2197   /// i.e. each index between [0..VF) is used exactly once in each submask of
2198   /// size VF.
2199   /// For example, the mask for \p VF=4 is:
2200   /// 0, 1, 2, 3, 3, 2, 0, 1 - "clustered", because each submask of size 4
2201   /// (0,1,2,3 and 3,2,0,1) uses indices [0..VF) exactly one time.
2202   /// 0, 1, 2, 3, 3, 3, 1, 0 - not "clustered", because
2203   ///                          element 3 is used twice in the second submask
2204   ///                          (3,3,1,0) and index 2 is not used at all.
2205   static bool isOneUseSingleSourceMask(ArrayRef<int> Mask, int VF);
2206 
2207   /// Return true if this shuffle mask is a one-use-single-source("clustered")
2208   /// mask.
2209   bool isOneUseSingleSourceMask(int VF) const;
2210 
2211   /// Change values in a shuffle permute mask assuming the two vector operands
2212   /// of length InVecNumElts have swapped position.
2213   static void commuteShuffleMask(MutableArrayRef<int> Mask,
2214                                  unsigned InVecNumElts) {
2215     for (int &Idx : Mask) {
2216       if (Idx == -1)
2217         continue;
2218       Idx = Idx < (int)InVecNumElts ? Idx + InVecNumElts : Idx - InVecNumElts;
2219       assert(Idx >= 0 && Idx < (int)InVecNumElts * 2 &&
2220              "shufflevector mask index out of range");
2221     }
2222   }
2223 
2224   /// Return if this shuffle interleaves its two input vectors together.
2225   bool isInterleave(unsigned Factor);
2226 
2227   /// Return true if the mask interleaves one or more input vectors together.
2228   ///
2229   /// I.e. <0, LaneLen, ... , LaneLen*(Factor - 1), 1, LaneLen + 1, ...>
2230   /// E.g. For a Factor of 2 (LaneLen=4):
2231   ///   <0, 4, 1, 5, 2, 6, 3, 7>
2232   /// E.g. For a Factor of 3 (LaneLen=4):
2233   ///   <4, 0, 9, 5, 1, 10, 6, 2, 11, 7, 3, 12>
2234   /// E.g. For a Factor of 4 (LaneLen=2):
2235   ///   <0, 2, 6, 4, 1, 3, 7, 5>
2236   ///
2237   /// NumInputElts is the total number of elements in the input vectors.
2238   ///
2239   /// StartIndexes are the first indexes of each vector being interleaved,
2240   /// substituting any indexes that were undef
2241   /// E.g. <4, -1, 2, 5, 1, 3> (Factor=3): StartIndexes=<4, 0, 2>
2242   ///
2243   /// Note that this does not check if the input vectors are consecutive:
2244   /// It will return true for masks such as
2245   /// <0, 4, 6, 1, 5, 7> (Factor=3, LaneLen=2)
2246   static bool isInterleaveMask(ArrayRef<int> Mask, unsigned Factor,
2247                                unsigned NumInputElts,
2248                                SmallVectorImpl<unsigned> &StartIndexes);
2249   static bool isInterleaveMask(ArrayRef<int> Mask, unsigned Factor,
2250                                unsigned NumInputElts) {
2251     SmallVector<unsigned, 8> StartIndexes;
2252     return isInterleaveMask(Mask, Factor, NumInputElts, StartIndexes);
2253   }
2254 
2255   /// Check if the mask is a DE-interleave mask of the given factor
2256   /// \p Factor like:
2257   ///     <Index, Index+Factor, ..., Index+(NumElts-1)*Factor>
2258   static bool isDeInterleaveMaskOfFactor(ArrayRef<int> Mask, unsigned Factor,
2259                                          unsigned &Index);
2260   static bool isDeInterleaveMaskOfFactor(ArrayRef<int> Mask, unsigned Factor) {
2261     unsigned Unused;
2262     return isDeInterleaveMaskOfFactor(Mask, Factor, Unused);
2263   }
2264 
2265   /// Checks if the shuffle is a bit rotation of the first operand across
2266   /// multiple subelements, e.g:
2267   ///
2268   /// shuffle <8 x i8> %a, <8 x i8> poison, <8 x i32> <1, 0, 3, 2, 5, 4, 7, 6>
2269   ///
2270   /// could be expressed as
2271   ///
2272   /// rotl <4 x i16> %a, 8
2273   ///
2274   /// If it can be expressed as a rotation, returns the number of subelements to
2275   /// group by in NumSubElts and the number of bits to rotate left in RotateAmt.
2276   static bool isBitRotateMask(ArrayRef<int> Mask, unsigned EltSizeInBits,
2277                               unsigned MinSubElts, unsigned MaxSubElts,
2278                               unsigned &NumSubElts, unsigned &RotateAmt);
2279 
2280   // Methods for support type inquiry through isa, cast, and dyn_cast:
2281   static bool classof(const Instruction *I) {
2282     return I->getOpcode() == Instruction::ShuffleVector;
2283   }
2284   static bool classof(const Value *V) {
2285     return isa<Instruction>(V) && classof(cast<Instruction>(V));
2286   }
2287 };
2288 
2289 template <>
2290 struct OperandTraits<ShuffleVectorInst>
2291     : public FixedNumOperandTraits<ShuffleVectorInst, 2> {};
2292 
2293 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(ShuffleVectorInst, Value)
2294 
2295 //===----------------------------------------------------------------------===//
2296 //                                ExtractValueInst Class
2297 //===----------------------------------------------------------------------===//
2298 
2299 /// This instruction extracts a struct member or array
2300 /// element value from an aggregate value.
2301 ///
2302 class ExtractValueInst : public UnaryInstruction {
2303   SmallVector<unsigned, 4> Indices;
2304 
2305   ExtractValueInst(const ExtractValueInst &EVI);
2306 
2307   /// Constructors - Create a extractvalue instruction with a base aggregate
2308   /// value and a list of indices. The first and second ctor can optionally
2309   /// insert before an existing instruction, the third appends the new
2310   /// instruction to the specified BasicBlock.
2311   inline ExtractValueInst(Value *Agg, ArrayRef<unsigned> Idxs,
2312                           const Twine &NameStr, InsertPosition InsertBefore);
2313 
2314   void init(ArrayRef<unsigned> Idxs, const Twine &NameStr);
2315 
2316 protected:
2317   // Note: Instruction needs to be a friend here to call cloneImpl.
2318   friend class Instruction;
2319 
2320   ExtractValueInst *cloneImpl() const;
2321 
2322 public:
2323   static ExtractValueInst *Create(Value *Agg, ArrayRef<unsigned> Idxs,
2324                                   const Twine &NameStr = "",
2325                                   InsertPosition InsertBefore = nullptr) {
2326     return new
2327       ExtractValueInst(Agg, Idxs, NameStr, InsertBefore);
2328   }
2329 
2330   /// Returns the type of the element that would be extracted
2331   /// with an extractvalue instruction with the specified parameters.
2332   ///
2333   /// Null is returned if the indices are invalid for the specified type.
2334   static Type *getIndexedType(Type *Agg, ArrayRef<unsigned> Idxs);
2335 
2336   using idx_iterator = const unsigned*;
2337 
2338   inline idx_iterator idx_begin() const { return Indices.begin(); }
2339   inline idx_iterator idx_end()   const { return Indices.end(); }
2340   inline iterator_range<idx_iterator> indices() const {
2341     return make_range(idx_begin(), idx_end());
2342   }
2343 
2344   Value *getAggregateOperand() {
2345     return getOperand(0);
2346   }
2347   const Value *getAggregateOperand() const {
2348     return getOperand(0);
2349   }
2350   static unsigned getAggregateOperandIndex() {
2351     return 0U;                      // get index for modifying correct operand
2352   }
2353 
2354   ArrayRef<unsigned> getIndices() const {
2355     return Indices;
2356   }
2357 
2358   unsigned getNumIndices() const {
2359     return (unsigned)Indices.size();
2360   }
2361 
2362   bool hasIndices() const {
2363     return true;
2364   }
2365 
2366   // Methods for support type inquiry through isa, cast, and dyn_cast:
2367   static bool classof(const Instruction *I) {
2368     return I->getOpcode() == Instruction::ExtractValue;
2369   }
2370   static bool classof(const Value *V) {
2371     return isa<Instruction>(V) && classof(cast<Instruction>(V));
2372   }
2373 };
2374 
2375 ExtractValueInst::ExtractValueInst(Value *Agg, ArrayRef<unsigned> Idxs,
2376                                    const Twine &NameStr,
2377                                    InsertPosition InsertBefore)
2378     : UnaryInstruction(checkGEPType(getIndexedType(Agg->getType(), Idxs)),
2379                        ExtractValue, Agg, InsertBefore) {
2380   init(Idxs, NameStr);
2381 }
2382 
2383 //===----------------------------------------------------------------------===//
2384 //                                InsertValueInst Class
2385 //===----------------------------------------------------------------------===//
2386 
2387 /// This instruction inserts a struct field of array element
2388 /// value into an aggregate value.
2389 ///
2390 class InsertValueInst : public Instruction {
2391   SmallVector<unsigned, 4> Indices;
2392 
2393   InsertValueInst(const InsertValueInst &IVI);
2394 
2395   /// Constructors - Create a insertvalue instruction with a base aggregate
2396   /// value, a value to insert, and a list of indices. The first and second ctor
2397   /// can optionally insert before an existing instruction, the third appends
2398   /// the new instruction to the specified BasicBlock.
2399   inline InsertValueInst(Value *Agg, Value *Val, ArrayRef<unsigned> Idxs,
2400                          const Twine &NameStr, InsertPosition InsertBefore);
2401 
2402   /// Constructors - These three constructors are convenience methods because
2403   /// one and two index insertvalue instructions are so common.
2404   InsertValueInst(Value *Agg, Value *Val, unsigned Idx,
2405                   const Twine &NameStr = "",
2406                   InsertPosition InsertBefore = nullptr);
2407 
2408   void init(Value *Agg, Value *Val, ArrayRef<unsigned> Idxs,
2409             const Twine &NameStr);
2410 
2411 protected:
2412   // Note: Instruction needs to be a friend here to call cloneImpl.
2413   friend class Instruction;
2414 
2415   InsertValueInst *cloneImpl() const;
2416 
2417 public:
2418   // allocate space for exactly two operands
2419   void *operator new(size_t S) { return User::operator new(S, 2); }
2420   void operator delete(void *Ptr) { User::operator delete(Ptr); }
2421 
2422   static InsertValueInst *Create(Value *Agg, Value *Val,
2423                                  ArrayRef<unsigned> Idxs,
2424                                  const Twine &NameStr = "",
2425                                  InsertPosition InsertBefore = nullptr) {
2426     return new InsertValueInst(Agg, Val, Idxs, NameStr, InsertBefore);
2427   }
2428 
2429   /// Transparently provide more efficient getOperand methods.
2430   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
2431 
2432   using idx_iterator = const unsigned*;
2433 
2434   inline idx_iterator idx_begin() const { return Indices.begin(); }
2435   inline idx_iterator idx_end()   const { return Indices.end(); }
2436   inline iterator_range<idx_iterator> indices() const {
2437     return make_range(idx_begin(), idx_end());
2438   }
2439 
2440   Value *getAggregateOperand() {
2441     return getOperand(0);
2442   }
2443   const Value *getAggregateOperand() const {
2444     return getOperand(0);
2445   }
2446   static unsigned getAggregateOperandIndex() {
2447     return 0U;                      // get index for modifying correct operand
2448   }
2449 
2450   Value *getInsertedValueOperand() {
2451     return getOperand(1);
2452   }
2453   const Value *getInsertedValueOperand() const {
2454     return getOperand(1);
2455   }
2456   static unsigned getInsertedValueOperandIndex() {
2457     return 1U;                      // get index for modifying correct operand
2458   }
2459 
2460   ArrayRef<unsigned> getIndices() const {
2461     return Indices;
2462   }
2463 
2464   unsigned getNumIndices() const {
2465     return (unsigned)Indices.size();
2466   }
2467 
2468   bool hasIndices() const {
2469     return true;
2470   }
2471 
2472   // Methods for support type inquiry through isa, cast, and dyn_cast:
2473   static bool classof(const Instruction *I) {
2474     return I->getOpcode() == Instruction::InsertValue;
2475   }
2476   static bool classof(const Value *V) {
2477     return isa<Instruction>(V) && classof(cast<Instruction>(V));
2478   }
2479 };
2480 
2481 template <>
2482 struct OperandTraits<InsertValueInst> :
2483   public FixedNumOperandTraits<InsertValueInst, 2> {
2484 };
2485 
2486 InsertValueInst::InsertValueInst(Value *Agg, Value *Val,
2487                                  ArrayRef<unsigned> Idxs, const Twine &NameStr,
2488                                  InsertPosition InsertBefore)
2489     : Instruction(Agg->getType(), InsertValue,
2490                   OperandTraits<InsertValueInst>::op_begin(this), 2,
2491                   InsertBefore) {
2492   init(Agg, Val, Idxs, NameStr);
2493 }
2494 
2495 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(InsertValueInst, Value)
2496 
2497 //===----------------------------------------------------------------------===//
2498 //                               PHINode Class
2499 //===----------------------------------------------------------------------===//
2500 
2501 // PHINode - The PHINode class is used to represent the magical mystical PHI
2502 // node, that can not exist in nature, but can be synthesized in a computer
2503 // scientist's overactive imagination.
2504 //
2505 class PHINode : public Instruction {
2506   /// The number of operands actually allocated.  NumOperands is
2507   /// the number actually in use.
2508   unsigned ReservedSpace;
2509 
2510   PHINode(const PHINode &PN);
2511 
2512   explicit PHINode(Type *Ty, unsigned NumReservedValues,
2513                    const Twine &NameStr = "",
2514                    InsertPosition InsertBefore = nullptr)
2515       : Instruction(Ty, Instruction::PHI, nullptr, 0, InsertBefore),
2516         ReservedSpace(NumReservedValues) {
2517     assert(!Ty->isTokenTy() && "PHI nodes cannot have token type!");
2518     setName(NameStr);
2519     allocHungoffUses(ReservedSpace);
2520   }
2521 
2522 protected:
2523   // Note: Instruction needs to be a friend here to call cloneImpl.
2524   friend class Instruction;
2525 
2526   PHINode *cloneImpl() const;
2527 
2528   // allocHungoffUses - this is more complicated than the generic
2529   // User::allocHungoffUses, because we have to allocate Uses for the incoming
2530   // values and pointers to the incoming blocks, all in one allocation.
2531   void allocHungoffUses(unsigned N) {
2532     User::allocHungoffUses(N, /* IsPhi */ true);
2533   }
2534 
2535 public:
2536   /// Constructors - NumReservedValues is a hint for the number of incoming
2537   /// edges that this phi node will have (use 0 if you really have no idea).
2538   static PHINode *Create(Type *Ty, unsigned NumReservedValues,
2539                          const Twine &NameStr = "",
2540                          InsertPosition InsertBefore = nullptr) {
2541     return new PHINode(Ty, NumReservedValues, NameStr, InsertBefore);
2542   }
2543 
2544   /// Provide fast operand accessors
2545   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
2546 
2547   // Block iterator interface. This provides access to the list of incoming
2548   // basic blocks, which parallels the list of incoming values.
2549   // Please note that we are not providing non-const iterators for blocks to
2550   // force all updates go through an interface function.
2551 
2552   using block_iterator = BasicBlock **;
2553   using const_block_iterator = BasicBlock * const *;
2554 
2555   const_block_iterator block_begin() const {
2556     return reinterpret_cast<const_block_iterator>(op_begin() + ReservedSpace);
2557   }
2558 
2559   const_block_iterator block_end() const {
2560     return block_begin() + getNumOperands();
2561   }
2562 
2563   iterator_range<const_block_iterator> blocks() const {
2564     return make_range(block_begin(), block_end());
2565   }
2566 
2567   op_range incoming_values() { return operands(); }
2568 
2569   const_op_range incoming_values() const { return operands(); }
2570 
2571   /// Return the number of incoming edges
2572   ///
2573   unsigned getNumIncomingValues() const { return getNumOperands(); }
2574 
2575   /// Return incoming value number x
2576   ///
2577   Value *getIncomingValue(unsigned i) const {
2578     return getOperand(i);
2579   }
2580   void setIncomingValue(unsigned i, Value *V) {
2581     assert(V && "PHI node got a null value!");
2582     assert(getType() == V->getType() &&
2583            "All operands to PHI node must be the same type as the PHI node!");
2584     setOperand(i, V);
2585   }
2586 
2587   static unsigned getOperandNumForIncomingValue(unsigned i) {
2588     return i;
2589   }
2590 
2591   static unsigned getIncomingValueNumForOperand(unsigned i) {
2592     return i;
2593   }
2594 
2595   /// Return incoming basic block number @p i.
2596   ///
2597   BasicBlock *getIncomingBlock(unsigned i) const {
2598     return block_begin()[i];
2599   }
2600 
2601   /// Return incoming basic block corresponding
2602   /// to an operand of the PHI.
2603   ///
2604   BasicBlock *getIncomingBlock(const Use &U) const {
2605     assert(this == U.getUser() && "Iterator doesn't point to PHI's Uses?");
2606     return getIncomingBlock(unsigned(&U - op_begin()));
2607   }
2608 
2609   /// Return incoming basic block corresponding
2610   /// to value use iterator.
2611   ///
2612   BasicBlock *getIncomingBlock(Value::const_user_iterator I) const {
2613     return getIncomingBlock(I.getUse());
2614   }
2615 
2616   void setIncomingBlock(unsigned i, BasicBlock *BB) {
2617     const_cast<block_iterator>(block_begin())[i] = BB;
2618   }
2619 
2620   /// Copies the basic blocks from \p BBRange to the incoming basic block list
2621   /// of this PHINode, starting at \p ToIdx.
2622   void copyIncomingBlocks(iterator_range<const_block_iterator> BBRange,
2623                           uint32_t ToIdx = 0) {
2624     copy(BBRange, const_cast<block_iterator>(block_begin()) + ToIdx);
2625   }
2626 
2627   /// Replace every incoming basic block \p Old to basic block \p New.
2628   void replaceIncomingBlockWith(const BasicBlock *Old, BasicBlock *New) {
2629     assert(New && Old && "PHI node got a null basic block!");
2630     for (unsigned Op = 0, NumOps = getNumOperands(); Op != NumOps; ++Op)
2631       if (getIncomingBlock(Op) == Old)
2632         setIncomingBlock(Op, New);
2633   }
2634 
2635   /// Add an incoming value to the end of the PHI list
2636   ///
2637   void addIncoming(Value *V, BasicBlock *BB) {
2638     if (getNumOperands() == ReservedSpace)
2639       growOperands();  // Get more space!
2640     // Initialize some new operands.
2641     setNumHungOffUseOperands(getNumOperands() + 1);
2642     setIncomingValue(getNumOperands() - 1, V);
2643     setIncomingBlock(getNumOperands() - 1, BB);
2644   }
2645 
2646   /// Remove an incoming value.  This is useful if a
2647   /// predecessor basic block is deleted.  The value removed is returned.
2648   ///
2649   /// If the last incoming value for a PHI node is removed (and DeletePHIIfEmpty
2650   /// is true), the PHI node is destroyed and any uses of it are replaced with
2651   /// dummy values.  The only time there should be zero incoming values to a PHI
2652   /// node is when the block is dead, so this strategy is sound.
2653   ///
2654   Value *removeIncomingValue(unsigned Idx, bool DeletePHIIfEmpty = true);
2655 
2656   Value *removeIncomingValue(const BasicBlock *BB, bool DeletePHIIfEmpty=true) {
2657     int Idx = getBasicBlockIndex(BB);
2658     assert(Idx >= 0 && "Invalid basic block argument to remove!");
2659     return removeIncomingValue(Idx, DeletePHIIfEmpty);
2660   }
2661 
2662   /// Remove all incoming values for which the predicate returns true.
2663   /// The predicate accepts the incoming value index.
2664   void removeIncomingValueIf(function_ref<bool(unsigned)> Predicate,
2665                              bool DeletePHIIfEmpty = true);
2666 
2667   /// Return the first index of the specified basic
2668   /// block in the value list for this PHI.  Returns -1 if no instance.
2669   ///
2670   int getBasicBlockIndex(const BasicBlock *BB) const {
2671     for (unsigned i = 0, e = getNumOperands(); i != e; ++i)
2672       if (block_begin()[i] == BB)
2673         return i;
2674     return -1;
2675   }
2676 
2677   Value *getIncomingValueForBlock(const BasicBlock *BB) const {
2678     int Idx = getBasicBlockIndex(BB);
2679     assert(Idx >= 0 && "Invalid basic block argument!");
2680     return getIncomingValue(Idx);
2681   }
2682 
2683   /// Set every incoming value(s) for block \p BB to \p V.
2684   void setIncomingValueForBlock(const BasicBlock *BB, Value *V) {
2685     assert(BB && "PHI node got a null basic block!");
2686     bool Found = false;
2687     for (unsigned Op = 0, NumOps = getNumOperands(); Op != NumOps; ++Op)
2688       if (getIncomingBlock(Op) == BB) {
2689         Found = true;
2690         setIncomingValue(Op, V);
2691       }
2692     (void)Found;
2693     assert(Found && "Invalid basic block argument to set!");
2694   }
2695 
2696   /// If the specified PHI node always merges together the
2697   /// same value, return the value, otherwise return null.
2698   Value *hasConstantValue() const;
2699 
2700   /// Whether the specified PHI node always merges
2701   /// together the same value, assuming undefs are equal to a unique
2702   /// non-undef value.
2703   bool hasConstantOrUndefValue() const;
2704 
2705   /// If the PHI node is complete which means all of its parent's predecessors
2706   /// have incoming value in this PHI, return true, otherwise return false.
2707   bool isComplete() const {
2708     return llvm::all_of(predecessors(getParent()),
2709                         [this](const BasicBlock *Pred) {
2710                           return getBasicBlockIndex(Pred) >= 0;
2711                         });
2712   }
2713 
2714   /// Methods for support type inquiry through isa, cast, and dyn_cast:
2715   static bool classof(const Instruction *I) {
2716     return I->getOpcode() == Instruction::PHI;
2717   }
2718   static bool classof(const Value *V) {
2719     return isa<Instruction>(V) && classof(cast<Instruction>(V));
2720   }
2721 
2722 private:
2723   void growOperands();
2724 };
2725 
2726 template <>
2727 struct OperandTraits<PHINode> : public HungoffOperandTraits<2> {
2728 };
2729 
2730 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(PHINode, Value)
2731 
2732 //===----------------------------------------------------------------------===//
2733 //                           LandingPadInst Class
2734 //===----------------------------------------------------------------------===//
2735 
2736 //===---------------------------------------------------------------------------
2737 /// The landingpad instruction holds all of the information
2738 /// necessary to generate correct exception handling. The landingpad instruction
2739 /// cannot be moved from the top of a landing pad block, which itself is
2740 /// accessible only from the 'unwind' edge of an invoke. This uses the
2741 /// SubclassData field in Value to store whether or not the landingpad is a
2742 /// cleanup.
2743 ///
2744 class LandingPadInst : public Instruction {
2745   using CleanupField = BoolBitfieldElementT<0>;
2746 
2747   /// The number of operands actually allocated.  NumOperands is
2748   /// the number actually in use.
2749   unsigned ReservedSpace;
2750 
2751   LandingPadInst(const LandingPadInst &LP);
2752 
2753 public:
2754   enum ClauseType { Catch, Filter };
2755 
2756 private:
2757   explicit LandingPadInst(Type *RetTy, unsigned NumReservedValues,
2758                           const Twine &NameStr, InsertPosition InsertBefore);
2759 
2760   // Allocate space for exactly zero operands.
2761   void *operator new(size_t S) { return User::operator new(S); }
2762 
2763   void growOperands(unsigned Size);
2764   void init(unsigned NumReservedValues, const Twine &NameStr);
2765 
2766 protected:
2767   // Note: Instruction needs to be a friend here to call cloneImpl.
2768   friend class Instruction;
2769 
2770   LandingPadInst *cloneImpl() const;
2771 
2772 public:
2773   void operator delete(void *Ptr) { User::operator delete(Ptr); }
2774 
2775   /// Constructors - NumReservedClauses is a hint for the number of incoming
2776   /// clauses that this landingpad will have (use 0 if you really have no idea).
2777   static LandingPadInst *Create(Type *RetTy, unsigned NumReservedClauses,
2778                                 const Twine &NameStr = "",
2779                                 InsertPosition InsertBefore = nullptr);
2780 
2781   /// Provide fast operand accessors
2782   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
2783 
2784   /// Return 'true' if this landingpad instruction is a
2785   /// cleanup. I.e., it should be run when unwinding even if its landing pad
2786   /// doesn't catch the exception.
2787   bool isCleanup() const { return getSubclassData<CleanupField>(); }
2788 
2789   /// Indicate that this landingpad instruction is a cleanup.
2790   void setCleanup(bool V) { setSubclassData<CleanupField>(V); }
2791 
2792   /// Add a catch or filter clause to the landing pad.
2793   void addClause(Constant *ClauseVal);
2794 
2795   /// Get the value of the clause at index Idx. Use isCatch/isFilter to
2796   /// determine what type of clause this is.
2797   Constant *getClause(unsigned Idx) const {
2798     return cast<Constant>(getOperandList()[Idx]);
2799   }
2800 
2801   /// Return 'true' if the clause and index Idx is a catch clause.
2802   bool isCatch(unsigned Idx) const {
2803     return !isa<ArrayType>(getOperandList()[Idx]->getType());
2804   }
2805 
2806   /// Return 'true' if the clause and index Idx is a filter clause.
2807   bool isFilter(unsigned Idx) const {
2808     return isa<ArrayType>(getOperandList()[Idx]->getType());
2809   }
2810 
2811   /// Get the number of clauses for this landing pad.
2812   unsigned getNumClauses() const { return getNumOperands(); }
2813 
2814   /// Grow the size of the operand list to accommodate the new
2815   /// number of clauses.
2816   void reserveClauses(unsigned Size) { growOperands(Size); }
2817 
2818   // Methods for support type inquiry through isa, cast, and dyn_cast:
2819   static bool classof(const Instruction *I) {
2820     return I->getOpcode() == Instruction::LandingPad;
2821   }
2822   static bool classof(const Value *V) {
2823     return isa<Instruction>(V) && classof(cast<Instruction>(V));
2824   }
2825 };
2826 
2827 template <>
2828 struct OperandTraits<LandingPadInst> : public HungoffOperandTraits<1> {
2829 };
2830 
2831 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(LandingPadInst, Value)
2832 
2833 //===----------------------------------------------------------------------===//
2834 //                               ReturnInst Class
2835 //===----------------------------------------------------------------------===//
2836 
2837 //===---------------------------------------------------------------------------
2838 /// Return a value (possibly void), from a function.  Execution
2839 /// does not continue in this function any longer.
2840 ///
2841 class ReturnInst : public Instruction {
2842   ReturnInst(const ReturnInst &RI);
2843 
2844 private:
2845   // ReturnInst constructors:
2846   // ReturnInst()                  - 'ret void' instruction
2847   // ReturnInst(    null)          - 'ret void' instruction
2848   // ReturnInst(Value* X)          - 'ret X'    instruction
2849   // ReturnInst(null, Iterator It) - 'ret void' instruction, insert before I
2850   // ReturnInst(Value* X, Iterator It) - 'ret X'    instruction, insert before I
2851   // ReturnInst(    null, Inst *I) - 'ret void' instruction, insert before I
2852   // ReturnInst(Value* X, Inst *I) - 'ret X'    instruction, insert before I
2853   // ReturnInst(    null, BB *B)   - 'ret void' instruction, insert @ end of B
2854   // ReturnInst(Value* X, BB *B)   - 'ret X'    instruction, insert @ end of B
2855   //
2856   // NOTE: If the Value* passed is of type void then the constructor behaves as
2857   // if it was passed NULL.
2858   explicit ReturnInst(LLVMContext &C, Value *retVal = nullptr,
2859                       InsertPosition InsertBefore = nullptr);
2860 
2861 protected:
2862   // Note: Instruction needs to be a friend here to call cloneImpl.
2863   friend class Instruction;
2864 
2865   ReturnInst *cloneImpl() const;
2866 
2867 public:
2868   static ReturnInst *Create(LLVMContext &C, Value *retVal = nullptr,
2869                             InsertPosition InsertBefore = nullptr) {
2870     return new(!!retVal) ReturnInst(C, retVal, InsertBefore);
2871   }
2872 
2873   static ReturnInst *Create(LLVMContext &C, BasicBlock *InsertAtEnd) {
2874     return new (0) ReturnInst(C, nullptr, InsertAtEnd);
2875   }
2876 
2877   /// Provide fast operand accessors
2878   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
2879 
2880   /// Convenience accessor. Returns null if there is no return value.
2881   Value *getReturnValue() const {
2882     return getNumOperands() != 0 ? getOperand(0) : nullptr;
2883   }
2884 
2885   unsigned getNumSuccessors() const { return 0; }
2886 
2887   // Methods for support type inquiry through isa, cast, and dyn_cast:
2888   static bool classof(const Instruction *I) {
2889     return (I->getOpcode() == Instruction::Ret);
2890   }
2891   static bool classof(const Value *V) {
2892     return isa<Instruction>(V) && classof(cast<Instruction>(V));
2893   }
2894 
2895 private:
2896   BasicBlock *getSuccessor(unsigned idx) const {
2897     llvm_unreachable("ReturnInst has no successors!");
2898   }
2899 
2900   void setSuccessor(unsigned idx, BasicBlock *B) {
2901     llvm_unreachable("ReturnInst has no successors!");
2902   }
2903 };
2904 
2905 template <>
2906 struct OperandTraits<ReturnInst> : public VariadicOperandTraits<ReturnInst> {
2907 };
2908 
2909 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(ReturnInst, Value)
2910 
2911 //===----------------------------------------------------------------------===//
2912 //                               BranchInst Class
2913 //===----------------------------------------------------------------------===//
2914 
2915 //===---------------------------------------------------------------------------
2916 /// Conditional or Unconditional Branch instruction.
2917 ///
2918 class BranchInst : public Instruction {
2919   /// Ops list - Branches are strange.  The operands are ordered:
2920   ///  [Cond, FalseDest,] TrueDest.  This makes some accessors faster because
2921   /// they don't have to check for cond/uncond branchness. These are mostly
2922   /// accessed relative from op_end().
2923   BranchInst(const BranchInst &BI);
2924   // BranchInst constructors (where {B, T, F} are blocks, and C is a condition):
2925   // BranchInst(BB *B)                           - 'br B'
2926   // BranchInst(BB* T, BB *F, Value *C)          - 'br C, T, F'
2927   // BranchInst(BB* B, Iter It)                  - 'br B'        insert before I
2928   // BranchInst(BB* T, BB *F, Value *C, Iter It) - 'br C, T, F', insert before I
2929   // BranchInst(BB* B, Inst *I)                  - 'br B'        insert before I
2930   // BranchInst(BB* T, BB *F, Value *C, Inst *I) - 'br C, T, F', insert before I
2931   // BranchInst(BB* B, BB *I)                    - 'br B'        insert at end
2932   // BranchInst(BB* T, BB *F, Value *C, BB *I)   - 'br C, T, F', insert at end
2933   explicit BranchInst(BasicBlock *IfTrue,
2934                       InsertPosition InsertBefore = nullptr);
2935   BranchInst(BasicBlock *IfTrue, BasicBlock *IfFalse, Value *Cond,
2936              InsertPosition InsertBefore = nullptr);
2937 
2938   void AssertOK();
2939 
2940 protected:
2941   // Note: Instruction needs to be a friend here to call cloneImpl.
2942   friend class Instruction;
2943 
2944   BranchInst *cloneImpl() const;
2945 
2946 public:
2947   /// Iterator type that casts an operand to a basic block.
2948   ///
2949   /// This only makes sense because the successors are stored as adjacent
2950   /// operands for branch instructions.
2951   struct succ_op_iterator
2952       : iterator_adaptor_base<succ_op_iterator, value_op_iterator,
2953                               std::random_access_iterator_tag, BasicBlock *,
2954                               ptrdiff_t, BasicBlock *, BasicBlock *> {
2955     explicit succ_op_iterator(value_op_iterator I) : iterator_adaptor_base(I) {}
2956 
2957     BasicBlock *operator*() const { return cast<BasicBlock>(*I); }
2958     BasicBlock *operator->() const { return operator*(); }
2959   };
2960 
2961   /// The const version of `succ_op_iterator`.
2962   struct const_succ_op_iterator
2963       : iterator_adaptor_base<const_succ_op_iterator, const_value_op_iterator,
2964                               std::random_access_iterator_tag,
2965                               const BasicBlock *, ptrdiff_t, const BasicBlock *,
2966                               const BasicBlock *> {
2967     explicit const_succ_op_iterator(const_value_op_iterator I)
2968         : iterator_adaptor_base(I) {}
2969 
2970     const BasicBlock *operator*() const { return cast<BasicBlock>(*I); }
2971     const BasicBlock *operator->() const { return operator*(); }
2972   };
2973 
2974   static BranchInst *Create(BasicBlock *IfTrue,
2975                             InsertPosition InsertBefore = nullptr) {
2976     return new(1) BranchInst(IfTrue, InsertBefore);
2977   }
2978 
2979   static BranchInst *Create(BasicBlock *IfTrue, BasicBlock *IfFalse,
2980                             Value *Cond,
2981                             InsertPosition InsertBefore = nullptr) {
2982     return new(3) BranchInst(IfTrue, IfFalse, Cond, InsertBefore);
2983   }
2984 
2985   /// Transparently provide more efficient getOperand methods.
2986   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
2987 
2988   bool isUnconditional() const { return getNumOperands() == 1; }
2989   bool isConditional()   const { return getNumOperands() == 3; }
2990 
2991   Value *getCondition() const {
2992     assert(isConditional() && "Cannot get condition of an uncond branch!");
2993     return Op<-3>();
2994   }
2995 
2996   void setCondition(Value *V) {
2997     assert(isConditional() && "Cannot set condition of unconditional branch!");
2998     Op<-3>() = V;
2999   }
3000 
3001   unsigned getNumSuccessors() const { return 1+isConditional(); }
3002 
3003   BasicBlock *getSuccessor(unsigned i) const {
3004     assert(i < getNumSuccessors() && "Successor # out of range for Branch!");
3005     return cast_or_null<BasicBlock>((&Op<-1>() - i)->get());
3006   }
3007 
3008   void setSuccessor(unsigned idx, BasicBlock *NewSucc) {
3009     assert(idx < getNumSuccessors() && "Successor # out of range for Branch!");
3010     *(&Op<-1>() - idx) = NewSucc;
3011   }
3012 
3013   /// Swap the successors of this branch instruction.
3014   ///
3015   /// Swaps the successors of the branch instruction. This also swaps any
3016   /// branch weight metadata associated with the instruction so that it
3017   /// continues to map correctly to each operand.
3018   void swapSuccessors();
3019 
3020   iterator_range<succ_op_iterator> successors() {
3021     return make_range(
3022         succ_op_iterator(std::next(value_op_begin(), isConditional() ? 1 : 0)),
3023         succ_op_iterator(value_op_end()));
3024   }
3025 
3026   iterator_range<const_succ_op_iterator> successors() const {
3027     return make_range(const_succ_op_iterator(
3028                           std::next(value_op_begin(), isConditional() ? 1 : 0)),
3029                       const_succ_op_iterator(value_op_end()));
3030   }
3031 
3032   // Methods for support type inquiry through isa, cast, and dyn_cast:
3033   static bool classof(const Instruction *I) {
3034     return (I->getOpcode() == Instruction::Br);
3035   }
3036   static bool classof(const Value *V) {
3037     return isa<Instruction>(V) && classof(cast<Instruction>(V));
3038   }
3039 };
3040 
3041 template <>
3042 struct OperandTraits<BranchInst> : public VariadicOperandTraits<BranchInst, 1> {
3043 };
3044 
3045 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(BranchInst, Value)
3046 
3047 //===----------------------------------------------------------------------===//
3048 //                               SwitchInst Class
3049 //===----------------------------------------------------------------------===//
3050 
3051 //===---------------------------------------------------------------------------
3052 /// Multiway switch
3053 ///
3054 class SwitchInst : public Instruction {
3055   unsigned ReservedSpace;
3056 
3057   // Operand[0]    = Value to switch on
3058   // Operand[1]    = Default basic block destination
3059   // Operand[2n  ] = Value to match
3060   // Operand[2n+1] = BasicBlock to go to on match
3061   SwitchInst(const SwitchInst &SI);
3062 
3063   /// Create a new switch instruction, specifying a value to switch on and a
3064   /// default destination. The number of additional cases can be specified here
3065   /// to make memory allocation more efficient. This constructor can also
3066   /// auto-insert before another instruction.
3067   SwitchInst(Value *Value, BasicBlock *Default, unsigned NumCases,
3068              InsertPosition InsertBefore);
3069 
3070   // allocate space for exactly zero operands
3071   void *operator new(size_t S) { return User::operator new(S); }
3072 
3073   void init(Value *Value, BasicBlock *Default, unsigned NumReserved);
3074   void growOperands();
3075 
3076 protected:
3077   // Note: Instruction needs to be a friend here to call cloneImpl.
3078   friend class Instruction;
3079 
3080   SwitchInst *cloneImpl() const;
3081 
3082 public:
3083   void operator delete(void *Ptr) { User::operator delete(Ptr); }
3084 
3085   // -2
3086   static const unsigned DefaultPseudoIndex = static_cast<unsigned>(~0L-1);
3087 
3088   template <typename CaseHandleT> class CaseIteratorImpl;
3089 
3090   /// A handle to a particular switch case. It exposes a convenient interface
3091   /// to both the case value and the successor block.
3092   ///
3093   /// We define this as a template and instantiate it to form both a const and
3094   /// non-const handle.
3095   template <typename SwitchInstT, typename ConstantIntT, typename BasicBlockT>
3096   class CaseHandleImpl {
3097     // Directly befriend both const and non-const iterators.
3098     friend class SwitchInst::CaseIteratorImpl<
3099         CaseHandleImpl<SwitchInstT, ConstantIntT, BasicBlockT>>;
3100 
3101   protected:
3102     // Expose the switch type we're parameterized with to the iterator.
3103     using SwitchInstType = SwitchInstT;
3104 
3105     SwitchInstT *SI;
3106     ptrdiff_t Index;
3107 
3108     CaseHandleImpl() = default;
3109     CaseHandleImpl(SwitchInstT *SI, ptrdiff_t Index) : SI(SI), Index(Index) {}
3110 
3111   public:
3112     /// Resolves case value for current case.
3113     ConstantIntT *getCaseValue() const {
3114       assert((unsigned)Index < SI->getNumCases() &&
3115              "Index out the number of cases.");
3116       return reinterpret_cast<ConstantIntT *>(SI->getOperand(2 + Index * 2));
3117     }
3118 
3119     /// Resolves successor for current case.
3120     BasicBlockT *getCaseSuccessor() const {
3121       assert(((unsigned)Index < SI->getNumCases() ||
3122               (unsigned)Index == DefaultPseudoIndex) &&
3123              "Index out the number of cases.");
3124       return SI->getSuccessor(getSuccessorIndex());
3125     }
3126 
3127     /// Returns number of current case.
3128     unsigned getCaseIndex() const { return Index; }
3129 
3130     /// Returns successor index for current case successor.
3131     unsigned getSuccessorIndex() const {
3132       assert(((unsigned)Index == DefaultPseudoIndex ||
3133               (unsigned)Index < SI->getNumCases()) &&
3134              "Index out the number of cases.");
3135       return (unsigned)Index != DefaultPseudoIndex ? Index + 1 : 0;
3136     }
3137 
3138     bool operator==(const CaseHandleImpl &RHS) const {
3139       assert(SI == RHS.SI && "Incompatible operators.");
3140       return Index == RHS.Index;
3141     }
3142   };
3143 
3144   using ConstCaseHandle =
3145       CaseHandleImpl<const SwitchInst, const ConstantInt, const BasicBlock>;
3146 
3147   class CaseHandle
3148       : public CaseHandleImpl<SwitchInst, ConstantInt, BasicBlock> {
3149     friend class SwitchInst::CaseIteratorImpl<CaseHandle>;
3150 
3151   public:
3152     CaseHandle(SwitchInst *SI, ptrdiff_t Index) : CaseHandleImpl(SI, Index) {}
3153 
3154     /// Sets the new value for current case.
3155     void setValue(ConstantInt *V) const {
3156       assert((unsigned)Index < SI->getNumCases() &&
3157              "Index out the number of cases.");
3158       SI->setOperand(2 + Index*2, reinterpret_cast<Value*>(V));
3159     }
3160 
3161     /// Sets the new successor for current case.
3162     void setSuccessor(BasicBlock *S) const {
3163       SI->setSuccessor(getSuccessorIndex(), S);
3164     }
3165   };
3166 
3167   template <typename CaseHandleT>
3168   class CaseIteratorImpl
3169       : public iterator_facade_base<CaseIteratorImpl<CaseHandleT>,
3170                                     std::random_access_iterator_tag,
3171                                     const CaseHandleT> {
3172     using SwitchInstT = typename CaseHandleT::SwitchInstType;
3173 
3174     CaseHandleT Case;
3175 
3176   public:
3177     /// Default constructed iterator is in an invalid state until assigned to
3178     /// a case for a particular switch.
3179     CaseIteratorImpl() = default;
3180 
3181     /// Initializes case iterator for given SwitchInst and for given
3182     /// case number.
3183     CaseIteratorImpl(SwitchInstT *SI, unsigned CaseNum) : Case(SI, CaseNum) {}
3184 
3185     /// Initializes case iterator for given SwitchInst and for given
3186     /// successor index.
3187     static CaseIteratorImpl fromSuccessorIndex(SwitchInstT *SI,
3188                                                unsigned SuccessorIndex) {
3189       assert(SuccessorIndex < SI->getNumSuccessors() &&
3190              "Successor index # out of range!");
3191       return SuccessorIndex != 0 ? CaseIteratorImpl(SI, SuccessorIndex - 1)
3192                                  : CaseIteratorImpl(SI, DefaultPseudoIndex);
3193     }
3194 
3195     /// Support converting to the const variant. This will be a no-op for const
3196     /// variant.
3197     operator CaseIteratorImpl<ConstCaseHandle>() const {
3198       return CaseIteratorImpl<ConstCaseHandle>(Case.SI, Case.Index);
3199     }
3200 
3201     CaseIteratorImpl &operator+=(ptrdiff_t N) {
3202       // Check index correctness after addition.
3203       // Note: Index == getNumCases() means end().
3204       assert(Case.Index + N >= 0 &&
3205              (unsigned)(Case.Index + N) <= Case.SI->getNumCases() &&
3206              "Case.Index out the number of cases.");
3207       Case.Index += N;
3208       return *this;
3209     }
3210     CaseIteratorImpl &operator-=(ptrdiff_t N) {
3211       // Check index correctness after subtraction.
3212       // Note: Case.Index == getNumCases() means end().
3213       assert(Case.Index - N >= 0 &&
3214              (unsigned)(Case.Index - N) <= Case.SI->getNumCases() &&
3215              "Case.Index out the number of cases.");
3216       Case.Index -= N;
3217       return *this;
3218     }
3219     ptrdiff_t operator-(const CaseIteratorImpl &RHS) const {
3220       assert(Case.SI == RHS.Case.SI && "Incompatible operators.");
3221       return Case.Index - RHS.Case.Index;
3222     }
3223     bool operator==(const CaseIteratorImpl &RHS) const {
3224       return Case == RHS.Case;
3225     }
3226     bool operator<(const CaseIteratorImpl &RHS) const {
3227       assert(Case.SI == RHS.Case.SI && "Incompatible operators.");
3228       return Case.Index < RHS.Case.Index;
3229     }
3230     const CaseHandleT &operator*() const { return Case; }
3231   };
3232 
3233   using CaseIt = CaseIteratorImpl<CaseHandle>;
3234   using ConstCaseIt = CaseIteratorImpl<ConstCaseHandle>;
3235 
3236   static SwitchInst *Create(Value *Value, BasicBlock *Default,
3237                             unsigned NumCases,
3238                             InsertPosition InsertBefore = nullptr) {
3239     return new SwitchInst(Value, Default, NumCases, InsertBefore);
3240   }
3241 
3242   /// Provide fast operand accessors
3243   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
3244 
3245   // Accessor Methods for Switch stmt
3246   Value *getCondition() const { return getOperand(0); }
3247   void setCondition(Value *V) { setOperand(0, V); }
3248 
3249   BasicBlock *getDefaultDest() const {
3250     return cast<BasicBlock>(getOperand(1));
3251   }
3252 
3253   /// Returns true if the default branch must result in immediate undefined
3254   /// behavior, false otherwise.
3255   bool defaultDestUndefined() const {
3256     return isa<UnreachableInst>(getDefaultDest()->getFirstNonPHIOrDbg());
3257   }
3258 
3259   void setDefaultDest(BasicBlock *DefaultCase) {
3260     setOperand(1, reinterpret_cast<Value*>(DefaultCase));
3261   }
3262 
3263   /// Return the number of 'cases' in this switch instruction, excluding the
3264   /// default case.
3265   unsigned getNumCases() const {
3266     return getNumOperands()/2 - 1;
3267   }
3268 
3269   /// Returns a read/write iterator that points to the first case in the
3270   /// SwitchInst.
3271   CaseIt case_begin() {
3272     return CaseIt(this, 0);
3273   }
3274 
3275   /// Returns a read-only iterator that points to the first case in the
3276   /// SwitchInst.
3277   ConstCaseIt case_begin() const {
3278     return ConstCaseIt(this, 0);
3279   }
3280 
3281   /// Returns a read/write iterator that points one past the last in the
3282   /// SwitchInst.
3283   CaseIt case_end() {
3284     return CaseIt(this, getNumCases());
3285   }
3286 
3287   /// Returns a read-only iterator that points one past the last in the
3288   /// SwitchInst.
3289   ConstCaseIt case_end() const {
3290     return ConstCaseIt(this, getNumCases());
3291   }
3292 
3293   /// Iteration adapter for range-for loops.
3294   iterator_range<CaseIt> cases() {
3295     return make_range(case_begin(), case_end());
3296   }
3297 
3298   /// Constant iteration adapter for range-for loops.
3299   iterator_range<ConstCaseIt> cases() const {
3300     return make_range(case_begin(), case_end());
3301   }
3302 
3303   /// Returns an iterator that points to the default case.
3304   /// Note: this iterator allows to resolve successor only. Attempt
3305   /// to resolve case value causes an assertion.
3306   /// Also note, that increment and decrement also causes an assertion and
3307   /// makes iterator invalid.
3308   CaseIt case_default() {
3309     return CaseIt(this, DefaultPseudoIndex);
3310   }
3311   ConstCaseIt case_default() const {
3312     return ConstCaseIt(this, DefaultPseudoIndex);
3313   }
3314 
3315   /// Search all of the case values for the specified constant. If it is
3316   /// explicitly handled, return the case iterator of it, otherwise return
3317   /// default case iterator to indicate that it is handled by the default
3318   /// handler.
3319   CaseIt findCaseValue(const ConstantInt *C) {
3320     return CaseIt(
3321         this,
3322         const_cast<const SwitchInst *>(this)->findCaseValue(C)->getCaseIndex());
3323   }
3324   ConstCaseIt findCaseValue(const ConstantInt *C) const {
3325     ConstCaseIt I = llvm::find_if(cases(), [C](const ConstCaseHandle &Case) {
3326       return Case.getCaseValue() == C;
3327     });
3328     if (I != case_end())
3329       return I;
3330 
3331     return case_default();
3332   }
3333 
3334   /// Finds the unique case value for a given successor. Returns null if the
3335   /// successor is not found, not unique, or is the default case.
3336   ConstantInt *findCaseDest(BasicBlock *BB) {
3337     if (BB == getDefaultDest())
3338       return nullptr;
3339 
3340     ConstantInt *CI = nullptr;
3341     for (auto Case : cases()) {
3342       if (Case.getCaseSuccessor() != BB)
3343         continue;
3344 
3345       if (CI)
3346         return nullptr; // Multiple cases lead to BB.
3347 
3348       CI = Case.getCaseValue();
3349     }
3350 
3351     return CI;
3352   }
3353 
3354   /// Add an entry to the switch instruction.
3355   /// Note:
3356   /// This action invalidates case_end(). Old case_end() iterator will
3357   /// point to the added case.
3358   void addCase(ConstantInt *OnVal, BasicBlock *Dest);
3359 
3360   /// This method removes the specified case and its successor from the switch
3361   /// instruction. Note that this operation may reorder the remaining cases at
3362   /// index idx and above.
3363   /// Note:
3364   /// This action invalidates iterators for all cases following the one removed,
3365   /// including the case_end() iterator. It returns an iterator for the next
3366   /// case.
3367   CaseIt removeCase(CaseIt I);
3368 
3369   unsigned getNumSuccessors() const { return getNumOperands()/2; }
3370   BasicBlock *getSuccessor(unsigned idx) const {
3371     assert(idx < getNumSuccessors() &&"Successor idx out of range for switch!");
3372     return cast<BasicBlock>(getOperand(idx*2+1));
3373   }
3374   void setSuccessor(unsigned idx, BasicBlock *NewSucc) {
3375     assert(idx < getNumSuccessors() && "Successor # out of range for switch!");
3376     setOperand(idx * 2 + 1, NewSucc);
3377   }
3378 
3379   // Methods for support type inquiry through isa, cast, and dyn_cast:
3380   static bool classof(const Instruction *I) {
3381     return I->getOpcode() == Instruction::Switch;
3382   }
3383   static bool classof(const Value *V) {
3384     return isa<Instruction>(V) && classof(cast<Instruction>(V));
3385   }
3386 };
3387 
3388 /// A wrapper class to simplify modification of SwitchInst cases along with
3389 /// their prof branch_weights metadata.
3390 class SwitchInstProfUpdateWrapper {
3391   SwitchInst &SI;
3392   std::optional<SmallVector<uint32_t, 8>> Weights;
3393   bool Changed = false;
3394 
3395 protected:
3396   MDNode *buildProfBranchWeightsMD();
3397 
3398   void init();
3399 
3400 public:
3401   using CaseWeightOpt = std::optional<uint32_t>;
3402   SwitchInst *operator->() { return &SI; }
3403   SwitchInst &operator*() { return SI; }
3404   operator SwitchInst *() { return &SI; }
3405 
3406   SwitchInstProfUpdateWrapper(SwitchInst &SI) : SI(SI) { init(); }
3407 
3408   ~SwitchInstProfUpdateWrapper() {
3409     if (Changed)
3410       SI.setMetadata(LLVMContext::MD_prof, buildProfBranchWeightsMD());
3411   }
3412 
3413   /// Delegate the call to the underlying SwitchInst::removeCase() and remove
3414   /// correspondent branch weight.
3415   SwitchInst::CaseIt removeCase(SwitchInst::CaseIt I);
3416 
3417   /// Delegate the call to the underlying SwitchInst::addCase() and set the
3418   /// specified branch weight for the added case.
3419   void addCase(ConstantInt *OnVal, BasicBlock *Dest, CaseWeightOpt W);
3420 
3421   /// Delegate the call to the underlying SwitchInst::eraseFromParent() and mark
3422   /// this object to not touch the underlying SwitchInst in destructor.
3423   Instruction::InstListType::iterator eraseFromParent();
3424 
3425   void setSuccessorWeight(unsigned idx, CaseWeightOpt W);
3426   CaseWeightOpt getSuccessorWeight(unsigned idx);
3427 
3428   static CaseWeightOpt getSuccessorWeight(const SwitchInst &SI, unsigned idx);
3429 };
3430 
3431 template <>
3432 struct OperandTraits<SwitchInst> : public HungoffOperandTraits<2> {
3433 };
3434 
3435 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(SwitchInst, Value)
3436 
3437 //===----------------------------------------------------------------------===//
3438 //                             IndirectBrInst Class
3439 //===----------------------------------------------------------------------===//
3440 
3441 //===---------------------------------------------------------------------------
3442 /// Indirect Branch Instruction.
3443 ///
3444 class IndirectBrInst : public Instruction {
3445   unsigned ReservedSpace;
3446 
3447   // Operand[0]   = Address to jump to
3448   // Operand[n+1] = n-th destination
3449   IndirectBrInst(const IndirectBrInst &IBI);
3450 
3451   /// Create a new indirectbr instruction, specifying an
3452   /// Address to jump to.  The number of expected destinations can be specified
3453   /// here to make memory allocation more efficient.  This constructor can also
3454   /// autoinsert before another instruction.
3455   IndirectBrInst(Value *Address, unsigned NumDests,
3456                  InsertPosition InsertBefore);
3457 
3458   // allocate space for exactly zero operands
3459   void *operator new(size_t S) { return User::operator new(S); }
3460 
3461   void init(Value *Address, unsigned NumDests);
3462   void growOperands();
3463 
3464 protected:
3465   // Note: Instruction needs to be a friend here to call cloneImpl.
3466   friend class Instruction;
3467 
3468   IndirectBrInst *cloneImpl() const;
3469 
3470 public:
3471   void operator delete(void *Ptr) { User::operator delete(Ptr); }
3472 
3473   /// Iterator type that casts an operand to a basic block.
3474   ///
3475   /// This only makes sense because the successors are stored as adjacent
3476   /// operands for indirectbr instructions.
3477   struct succ_op_iterator
3478       : iterator_adaptor_base<succ_op_iterator, value_op_iterator,
3479                               std::random_access_iterator_tag, BasicBlock *,
3480                               ptrdiff_t, BasicBlock *, BasicBlock *> {
3481     explicit succ_op_iterator(value_op_iterator I) : iterator_adaptor_base(I) {}
3482 
3483     BasicBlock *operator*() const { return cast<BasicBlock>(*I); }
3484     BasicBlock *operator->() const { return operator*(); }
3485   };
3486 
3487   /// The const version of `succ_op_iterator`.
3488   struct const_succ_op_iterator
3489       : iterator_adaptor_base<const_succ_op_iterator, const_value_op_iterator,
3490                               std::random_access_iterator_tag,
3491                               const BasicBlock *, ptrdiff_t, const BasicBlock *,
3492                               const BasicBlock *> {
3493     explicit const_succ_op_iterator(const_value_op_iterator I)
3494         : iterator_adaptor_base(I) {}
3495 
3496     const BasicBlock *operator*() const { return cast<BasicBlock>(*I); }
3497     const BasicBlock *operator->() const { return operator*(); }
3498   };
3499 
3500   static IndirectBrInst *Create(Value *Address, unsigned NumDests,
3501                                 InsertPosition InsertBefore = nullptr) {
3502     return new IndirectBrInst(Address, NumDests, InsertBefore);
3503   }
3504 
3505   /// Provide fast operand accessors.
3506   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
3507 
3508   // Accessor Methods for IndirectBrInst instruction.
3509   Value *getAddress() { return getOperand(0); }
3510   const Value *getAddress() const { return getOperand(0); }
3511   void setAddress(Value *V) { setOperand(0, V); }
3512 
3513   /// return the number of possible destinations in this
3514   /// indirectbr instruction.
3515   unsigned getNumDestinations() const { return getNumOperands()-1; }
3516 
3517   /// Return the specified destination.
3518   BasicBlock *getDestination(unsigned i) { return getSuccessor(i); }
3519   const BasicBlock *getDestination(unsigned i) const { return getSuccessor(i); }
3520 
3521   /// Add a destination.
3522   ///
3523   void addDestination(BasicBlock *Dest);
3524 
3525   /// This method removes the specified successor from the
3526   /// indirectbr instruction.
3527   void removeDestination(unsigned i);
3528 
3529   unsigned getNumSuccessors() const { return getNumOperands()-1; }
3530   BasicBlock *getSuccessor(unsigned i) const {
3531     return cast<BasicBlock>(getOperand(i+1));
3532   }
3533   void setSuccessor(unsigned i, BasicBlock *NewSucc) {
3534     setOperand(i + 1, NewSucc);
3535   }
3536 
3537   iterator_range<succ_op_iterator> successors() {
3538     return make_range(succ_op_iterator(std::next(value_op_begin())),
3539                       succ_op_iterator(value_op_end()));
3540   }
3541 
3542   iterator_range<const_succ_op_iterator> successors() const {
3543     return make_range(const_succ_op_iterator(std::next(value_op_begin())),
3544                       const_succ_op_iterator(value_op_end()));
3545   }
3546 
3547   // Methods for support type inquiry through isa, cast, and dyn_cast:
3548   static bool classof(const Instruction *I) {
3549     return I->getOpcode() == Instruction::IndirectBr;
3550   }
3551   static bool classof(const Value *V) {
3552     return isa<Instruction>(V) && classof(cast<Instruction>(V));
3553   }
3554 };
3555 
3556 template <>
3557 struct OperandTraits<IndirectBrInst> : public HungoffOperandTraits<1> {
3558 };
3559 
3560 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(IndirectBrInst, Value)
3561 
3562 //===----------------------------------------------------------------------===//
3563 //                               InvokeInst Class
3564 //===----------------------------------------------------------------------===//
3565 
3566 /// Invoke instruction.  The SubclassData field is used to hold the
3567 /// calling convention of the call.
3568 ///
3569 class InvokeInst : public CallBase {
3570   /// The number of operands for this call beyond the called function,
3571   /// arguments, and operand bundles.
3572   static constexpr int NumExtraOperands = 2;
3573 
3574   /// The index from the end of the operand array to the normal destination.
3575   static constexpr int NormalDestOpEndIdx = -3;
3576 
3577   /// The index from the end of the operand array to the unwind destination.
3578   static constexpr int UnwindDestOpEndIdx = -2;
3579 
3580   InvokeInst(const InvokeInst &BI);
3581 
3582   /// Construct an InvokeInst given a range of arguments.
3583   ///
3584   /// Construct an InvokeInst from a range of arguments
3585   inline InvokeInst(FunctionType *Ty, Value *Func, BasicBlock *IfNormal,
3586                     BasicBlock *IfException, ArrayRef<Value *> Args,
3587                     ArrayRef<OperandBundleDef> Bundles, int NumOperands,
3588                     const Twine &NameStr, InsertPosition InsertBefore);
3589 
3590   void init(FunctionType *Ty, Value *Func, BasicBlock *IfNormal,
3591             BasicBlock *IfException, ArrayRef<Value *> Args,
3592             ArrayRef<OperandBundleDef> Bundles, const Twine &NameStr);
3593 
3594   /// Compute the number of operands to allocate.
3595   static int ComputeNumOperands(int NumArgs, int NumBundleInputs = 0) {
3596     // We need one operand for the called function, plus our extra operands and
3597     // the input operand counts provided.
3598     return 1 + NumExtraOperands + NumArgs + NumBundleInputs;
3599   }
3600 
3601 protected:
3602   // Note: Instruction needs to be a friend here to call cloneImpl.
3603   friend class Instruction;
3604 
3605   InvokeInst *cloneImpl() const;
3606 
3607 public:
3608   static InvokeInst *Create(FunctionType *Ty, Value *Func, BasicBlock *IfNormal,
3609                             BasicBlock *IfException, ArrayRef<Value *> Args,
3610                             const Twine &NameStr,
3611                             InsertPosition InsertBefore = nullptr) {
3612     int NumOperands = ComputeNumOperands(Args.size());
3613     return new (NumOperands)
3614         InvokeInst(Ty, Func, IfNormal, IfException, Args, std::nullopt,
3615                    NumOperands, NameStr, InsertBefore);
3616   }
3617 
3618   static InvokeInst *Create(FunctionType *Ty, Value *Func, BasicBlock *IfNormal,
3619                             BasicBlock *IfException, ArrayRef<Value *> Args,
3620                             ArrayRef<OperandBundleDef> Bundles = std::nullopt,
3621                             const Twine &NameStr = "",
3622                             InsertPosition InsertBefore = nullptr) {
3623     int NumOperands =
3624         ComputeNumOperands(Args.size(), CountBundleInputs(Bundles));
3625     unsigned DescriptorBytes = Bundles.size() * sizeof(BundleOpInfo);
3626 
3627     return new (NumOperands, DescriptorBytes)
3628         InvokeInst(Ty, Func, IfNormal, IfException, Args, Bundles, NumOperands,
3629                    NameStr, InsertBefore);
3630   }
3631 
3632   static InvokeInst *Create(FunctionCallee Func, BasicBlock *IfNormal,
3633                             BasicBlock *IfException, ArrayRef<Value *> Args,
3634                             const Twine &NameStr,
3635                             InsertPosition InsertBefore = nullptr) {
3636     return Create(Func.getFunctionType(), Func.getCallee(), IfNormal,
3637                   IfException, Args, std::nullopt, NameStr, InsertBefore);
3638   }
3639 
3640   static InvokeInst *Create(FunctionCallee Func, BasicBlock *IfNormal,
3641                             BasicBlock *IfException, ArrayRef<Value *> Args,
3642                             ArrayRef<OperandBundleDef> Bundles = std::nullopt,
3643                             const Twine &NameStr = "",
3644                             InsertPosition InsertBefore = nullptr) {
3645     return Create(Func.getFunctionType(), Func.getCallee(), IfNormal,
3646                   IfException, Args, Bundles, NameStr, InsertBefore);
3647   }
3648 
3649   /// Create a clone of \p II with a different set of operand bundles and
3650   /// insert it before \p InsertBefore.
3651   ///
3652   /// The returned invoke instruction is identical to \p II in every way except
3653   /// that the operand bundles for the new instruction are set to the operand
3654   /// bundles in \p Bundles.
3655   static InvokeInst *Create(InvokeInst *II, ArrayRef<OperandBundleDef> Bundles,
3656                             InsertPosition InsertPt = nullptr);
3657 
3658   // get*Dest - Return the destination basic blocks...
3659   BasicBlock *getNormalDest() const {
3660     return cast<BasicBlock>(Op<NormalDestOpEndIdx>());
3661   }
3662   BasicBlock *getUnwindDest() const {
3663     return cast<BasicBlock>(Op<UnwindDestOpEndIdx>());
3664   }
3665   void setNormalDest(BasicBlock *B) {
3666     Op<NormalDestOpEndIdx>() = reinterpret_cast<Value *>(B);
3667   }
3668   void setUnwindDest(BasicBlock *B) {
3669     Op<UnwindDestOpEndIdx>() = reinterpret_cast<Value *>(B);
3670   }
3671 
3672   /// Get the landingpad instruction from the landing pad
3673   /// block (the unwind destination).
3674   LandingPadInst *getLandingPadInst() const;
3675 
3676   BasicBlock *getSuccessor(unsigned i) const {
3677     assert(i < 2 && "Successor # out of range for invoke!");
3678     return i == 0 ? getNormalDest() : getUnwindDest();
3679   }
3680 
3681   void setSuccessor(unsigned i, BasicBlock *NewSucc) {
3682     assert(i < 2 && "Successor # out of range for invoke!");
3683     if (i == 0)
3684       setNormalDest(NewSucc);
3685     else
3686       setUnwindDest(NewSucc);
3687   }
3688 
3689   unsigned getNumSuccessors() const { return 2; }
3690 
3691   /// Updates profile metadata by scaling it by \p S / \p T.
3692   void updateProfWeight(uint64_t S, uint64_t T);
3693 
3694   // Methods for support type inquiry through isa, cast, and dyn_cast:
3695   static bool classof(const Instruction *I) {
3696     return (I->getOpcode() == Instruction::Invoke);
3697   }
3698   static bool classof(const Value *V) {
3699     return isa<Instruction>(V) && classof(cast<Instruction>(V));
3700   }
3701 
3702 private:
3703   // Shadow Instruction::setInstructionSubclassData with a private forwarding
3704   // method so that subclasses cannot accidentally use it.
3705   template <typename Bitfield>
3706   void setSubclassData(typename Bitfield::Type Value) {
3707     Instruction::setSubclassData<Bitfield>(Value);
3708   }
3709 };
3710 
3711 InvokeInst::InvokeInst(FunctionType *Ty, Value *Func, BasicBlock *IfNormal,
3712                        BasicBlock *IfException, ArrayRef<Value *> Args,
3713                        ArrayRef<OperandBundleDef> Bundles, int NumOperands,
3714                        const Twine &NameStr, InsertPosition InsertBefore)
3715     : CallBase(Ty->getReturnType(), Instruction::Invoke,
3716                OperandTraits<CallBase>::op_end(this) - NumOperands, NumOperands,
3717                InsertBefore) {
3718   init(Ty, Func, IfNormal, IfException, Args, Bundles, NameStr);
3719 }
3720 
3721 //===----------------------------------------------------------------------===//
3722 //                              CallBrInst Class
3723 //===----------------------------------------------------------------------===//
3724 
3725 /// CallBr instruction, tracking function calls that may not return control but
3726 /// instead transfer it to a third location. The SubclassData field is used to
3727 /// hold the calling convention of the call.
3728 ///
3729 class CallBrInst : public CallBase {
3730 
3731   unsigned NumIndirectDests;
3732 
3733   CallBrInst(const CallBrInst &BI);
3734 
3735   /// Construct a CallBrInst given a range of arguments.
3736   ///
3737   /// Construct a CallBrInst from a range of arguments
3738   inline CallBrInst(FunctionType *Ty, Value *Func, BasicBlock *DefaultDest,
3739                     ArrayRef<BasicBlock *> IndirectDests,
3740                     ArrayRef<Value *> Args, ArrayRef<OperandBundleDef> Bundles,
3741                     int NumOperands, const Twine &NameStr,
3742                     InsertPosition InsertBefore);
3743 
3744   void init(FunctionType *FTy, Value *Func, BasicBlock *DefaultDest,
3745             ArrayRef<BasicBlock *> IndirectDests, ArrayRef<Value *> Args,
3746             ArrayRef<OperandBundleDef> Bundles, const Twine &NameStr);
3747 
3748   /// Compute the number of operands to allocate.
3749   static int ComputeNumOperands(int NumArgs, int NumIndirectDests,
3750                                 int NumBundleInputs = 0) {
3751     // We need one operand for the called function, plus our extra operands and
3752     // the input operand counts provided.
3753     return 2 + NumIndirectDests + NumArgs + NumBundleInputs;
3754   }
3755 
3756 protected:
3757   // Note: Instruction needs to be a friend here to call cloneImpl.
3758   friend class Instruction;
3759 
3760   CallBrInst *cloneImpl() const;
3761 
3762 public:
3763   static CallBrInst *Create(FunctionType *Ty, Value *Func,
3764                             BasicBlock *DefaultDest,
3765                             ArrayRef<BasicBlock *> IndirectDests,
3766                             ArrayRef<Value *> Args, const Twine &NameStr,
3767                             InsertPosition InsertBefore = nullptr) {
3768     int NumOperands = ComputeNumOperands(Args.size(), IndirectDests.size());
3769     return new (NumOperands)
3770         CallBrInst(Ty, Func, DefaultDest, IndirectDests, Args, std::nullopt,
3771                    NumOperands, NameStr, InsertBefore);
3772   }
3773 
3774   static CallBrInst *
3775   Create(FunctionType *Ty, Value *Func, BasicBlock *DefaultDest,
3776          ArrayRef<BasicBlock *> IndirectDests, ArrayRef<Value *> Args,
3777          ArrayRef<OperandBundleDef> Bundles = std::nullopt,
3778          const Twine &NameStr = "", InsertPosition InsertBefore = nullptr) {
3779     int NumOperands = ComputeNumOperands(Args.size(), IndirectDests.size(),
3780                                          CountBundleInputs(Bundles));
3781     unsigned DescriptorBytes = Bundles.size() * sizeof(BundleOpInfo);
3782 
3783     return new (NumOperands, DescriptorBytes)
3784         CallBrInst(Ty, Func, DefaultDest, IndirectDests, Args, Bundles,
3785                    NumOperands, NameStr, InsertBefore);
3786   }
3787 
3788   static CallBrInst *Create(FunctionCallee Func, BasicBlock *DefaultDest,
3789                             ArrayRef<BasicBlock *> IndirectDests,
3790                             ArrayRef<Value *> Args, const Twine &NameStr,
3791                             InsertPosition InsertBefore = nullptr) {
3792     return Create(Func.getFunctionType(), Func.getCallee(), DefaultDest,
3793                   IndirectDests, Args, NameStr, InsertBefore);
3794   }
3795 
3796   static CallBrInst *Create(FunctionCallee Func, BasicBlock *DefaultDest,
3797                             ArrayRef<BasicBlock *> IndirectDests,
3798                             ArrayRef<Value *> Args,
3799                             ArrayRef<OperandBundleDef> Bundles = std::nullopt,
3800                             const Twine &NameStr = "",
3801                             InsertPosition InsertBefore = nullptr) {
3802     return Create(Func.getFunctionType(), Func.getCallee(), DefaultDest,
3803                   IndirectDests, Args, Bundles, NameStr, InsertBefore);
3804   }
3805 
3806   /// Create a clone of \p CBI with a different set of operand bundles and
3807   /// insert it before \p InsertBefore.
3808   ///
3809   /// The returned callbr instruction is identical to \p CBI in every way
3810   /// except that the operand bundles for the new instruction are set to the
3811   /// operand bundles in \p Bundles.
3812   static CallBrInst *Create(CallBrInst *CBI, ArrayRef<OperandBundleDef> Bundles,
3813                             InsertPosition InsertBefore = nullptr);
3814 
3815   /// Return the number of callbr indirect dest labels.
3816   ///
3817   unsigned getNumIndirectDests() const { return NumIndirectDests; }
3818 
3819   /// getIndirectDestLabel - Return the i-th indirect dest label.
3820   ///
3821   Value *getIndirectDestLabel(unsigned i) const {
3822     assert(i < getNumIndirectDests() && "Out of bounds!");
3823     return getOperand(i + arg_size() + getNumTotalBundleOperands() + 1);
3824   }
3825 
3826   Value *getIndirectDestLabelUse(unsigned i) const {
3827     assert(i < getNumIndirectDests() && "Out of bounds!");
3828     return getOperandUse(i + arg_size() + getNumTotalBundleOperands() + 1);
3829   }
3830 
3831   // Return the destination basic blocks...
3832   BasicBlock *getDefaultDest() const {
3833     return cast<BasicBlock>(*(&Op<-1>() - getNumIndirectDests() - 1));
3834   }
3835   BasicBlock *getIndirectDest(unsigned i) const {
3836     return cast_or_null<BasicBlock>(*(&Op<-1>() - getNumIndirectDests() + i));
3837   }
3838   SmallVector<BasicBlock *, 16> getIndirectDests() const {
3839     SmallVector<BasicBlock *, 16> IndirectDests;
3840     for (unsigned i = 0, e = getNumIndirectDests(); i < e; ++i)
3841       IndirectDests.push_back(getIndirectDest(i));
3842     return IndirectDests;
3843   }
3844   void setDefaultDest(BasicBlock *B) {
3845     *(&Op<-1>() - getNumIndirectDests() - 1) = reinterpret_cast<Value *>(B);
3846   }
3847   void setIndirectDest(unsigned i, BasicBlock *B) {
3848     *(&Op<-1>() - getNumIndirectDests() + i) = reinterpret_cast<Value *>(B);
3849   }
3850 
3851   BasicBlock *getSuccessor(unsigned i) const {
3852     assert(i < getNumSuccessors() + 1 &&
3853            "Successor # out of range for callbr!");
3854     return i == 0 ? getDefaultDest() : getIndirectDest(i - 1);
3855   }
3856 
3857   void setSuccessor(unsigned i, BasicBlock *NewSucc) {
3858     assert(i < getNumIndirectDests() + 1 &&
3859            "Successor # out of range for callbr!");
3860     return i == 0 ? setDefaultDest(NewSucc) : setIndirectDest(i - 1, NewSucc);
3861   }
3862 
3863   unsigned getNumSuccessors() const { return getNumIndirectDests() + 1; }
3864 
3865   // Methods for support type inquiry through isa, cast, and dyn_cast:
3866   static bool classof(const Instruction *I) {
3867     return (I->getOpcode() == Instruction::CallBr);
3868   }
3869   static bool classof(const Value *V) {
3870     return isa<Instruction>(V) && classof(cast<Instruction>(V));
3871   }
3872 
3873 private:
3874   // Shadow Instruction::setInstructionSubclassData with a private forwarding
3875   // method so that subclasses cannot accidentally use it.
3876   template <typename Bitfield>
3877   void setSubclassData(typename Bitfield::Type Value) {
3878     Instruction::setSubclassData<Bitfield>(Value);
3879   }
3880 };
3881 
3882 CallBrInst::CallBrInst(FunctionType *Ty, Value *Func, BasicBlock *DefaultDest,
3883                        ArrayRef<BasicBlock *> IndirectDests,
3884                        ArrayRef<Value *> Args,
3885                        ArrayRef<OperandBundleDef> Bundles, int NumOperands,
3886                        const Twine &NameStr, InsertPosition InsertBefore)
3887     : CallBase(Ty->getReturnType(), Instruction::CallBr,
3888                OperandTraits<CallBase>::op_end(this) - NumOperands, NumOperands,
3889                InsertBefore) {
3890   init(Ty, Func, DefaultDest, IndirectDests, Args, Bundles, NameStr);
3891 }
3892 
3893 //===----------------------------------------------------------------------===//
3894 //                              ResumeInst Class
3895 //===----------------------------------------------------------------------===//
3896 
3897 //===---------------------------------------------------------------------------
3898 /// Resume the propagation of an exception.
3899 ///
3900 class ResumeInst : public Instruction {
3901   ResumeInst(const ResumeInst &RI);
3902 
3903   explicit ResumeInst(Value *Exn, InsertPosition InsertBefore = nullptr);
3904 
3905 protected:
3906   // Note: Instruction needs to be a friend here to call cloneImpl.
3907   friend class Instruction;
3908 
3909   ResumeInst *cloneImpl() const;
3910 
3911 public:
3912   static ResumeInst *Create(Value *Exn, InsertPosition InsertBefore = nullptr) {
3913     return new(1) ResumeInst(Exn, InsertBefore);
3914   }
3915 
3916   /// Provide fast operand accessors
3917   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
3918 
3919   /// Convenience accessor.
3920   Value *getValue() const { return Op<0>(); }
3921 
3922   unsigned getNumSuccessors() const { return 0; }
3923 
3924   // Methods for support type inquiry through isa, cast, and dyn_cast:
3925   static bool classof(const Instruction *I) {
3926     return I->getOpcode() == Instruction::Resume;
3927   }
3928   static bool classof(const Value *V) {
3929     return isa<Instruction>(V) && classof(cast<Instruction>(V));
3930   }
3931 
3932 private:
3933   BasicBlock *getSuccessor(unsigned idx) const {
3934     llvm_unreachable("ResumeInst has no successors!");
3935   }
3936 
3937   void setSuccessor(unsigned idx, BasicBlock *NewSucc) {
3938     llvm_unreachable("ResumeInst has no successors!");
3939   }
3940 };
3941 
3942 template <>
3943 struct OperandTraits<ResumeInst> :
3944     public FixedNumOperandTraits<ResumeInst, 1> {
3945 };
3946 
3947 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(ResumeInst, Value)
3948 
3949 //===----------------------------------------------------------------------===//
3950 //                         CatchSwitchInst Class
3951 //===----------------------------------------------------------------------===//
3952 class CatchSwitchInst : public Instruction {
3953   using UnwindDestField = BoolBitfieldElementT<0>;
3954 
3955   /// The number of operands actually allocated.  NumOperands is
3956   /// the number actually in use.
3957   unsigned ReservedSpace;
3958 
3959   // Operand[0] = Outer scope
3960   // Operand[1] = Unwind block destination
3961   // Operand[n] = BasicBlock to go to on match
3962   CatchSwitchInst(const CatchSwitchInst &CSI);
3963 
3964   /// Create a new switch instruction, specifying a
3965   /// default destination.  The number of additional handlers can be specified
3966   /// here to make memory allocation more efficient.
3967   /// This constructor can also autoinsert before another instruction.
3968   CatchSwitchInst(Value *ParentPad, BasicBlock *UnwindDest,
3969                   unsigned NumHandlers, const Twine &NameStr,
3970                   InsertPosition InsertBefore);
3971 
3972   // allocate space for exactly zero operands
3973   void *operator new(size_t S) { return User::operator new(S); }
3974 
3975   void init(Value *ParentPad, BasicBlock *UnwindDest, unsigned NumReserved);
3976   void growOperands(unsigned Size);
3977 
3978 protected:
3979   // Note: Instruction needs to be a friend here to call cloneImpl.
3980   friend class Instruction;
3981 
3982   CatchSwitchInst *cloneImpl() const;
3983 
3984 public:
3985   void operator delete(void *Ptr) { return User::operator delete(Ptr); }
3986 
3987   static CatchSwitchInst *Create(Value *ParentPad, BasicBlock *UnwindDest,
3988                                  unsigned NumHandlers,
3989                                  const Twine &NameStr = "",
3990                                  InsertPosition InsertBefore = nullptr) {
3991     return new CatchSwitchInst(ParentPad, UnwindDest, NumHandlers, NameStr,
3992                                InsertBefore);
3993   }
3994 
3995   /// Provide fast operand accessors
3996   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
3997 
3998   // Accessor Methods for CatchSwitch stmt
3999   Value *getParentPad() const { return getOperand(0); }
4000   void setParentPad(Value *ParentPad) { setOperand(0, ParentPad); }
4001 
4002   // Accessor Methods for CatchSwitch stmt
4003   bool hasUnwindDest() const { return getSubclassData<UnwindDestField>(); }
4004   bool unwindsToCaller() const { return !hasUnwindDest(); }
4005   BasicBlock *getUnwindDest() const {
4006     if (hasUnwindDest())
4007       return cast<BasicBlock>(getOperand(1));
4008     return nullptr;
4009   }
4010   void setUnwindDest(BasicBlock *UnwindDest) {
4011     assert(UnwindDest);
4012     assert(hasUnwindDest());
4013     setOperand(1, UnwindDest);
4014   }
4015 
4016   /// return the number of 'handlers' in this catchswitch
4017   /// instruction, except the default handler
4018   unsigned getNumHandlers() const {
4019     if (hasUnwindDest())
4020       return getNumOperands() - 2;
4021     return getNumOperands() - 1;
4022   }
4023 
4024 private:
4025   static BasicBlock *handler_helper(Value *V) { return cast<BasicBlock>(V); }
4026   static const BasicBlock *handler_helper(const Value *V) {
4027     return cast<BasicBlock>(V);
4028   }
4029 
4030 public:
4031   using DerefFnTy = BasicBlock *(*)(Value *);
4032   using handler_iterator = mapped_iterator<op_iterator, DerefFnTy>;
4033   using handler_range = iterator_range<handler_iterator>;
4034   using ConstDerefFnTy = const BasicBlock *(*)(const Value *);
4035   using const_handler_iterator =
4036       mapped_iterator<const_op_iterator, ConstDerefFnTy>;
4037   using const_handler_range = iterator_range<const_handler_iterator>;
4038 
4039   /// Returns an iterator that points to the first handler in CatchSwitchInst.
4040   handler_iterator handler_begin() {
4041     op_iterator It = op_begin() + 1;
4042     if (hasUnwindDest())
4043       ++It;
4044     return handler_iterator(It, DerefFnTy(handler_helper));
4045   }
4046 
4047   /// Returns an iterator that points to the first handler in the
4048   /// CatchSwitchInst.
4049   const_handler_iterator handler_begin() const {
4050     const_op_iterator It = op_begin() + 1;
4051     if (hasUnwindDest())
4052       ++It;
4053     return const_handler_iterator(It, ConstDerefFnTy(handler_helper));
4054   }
4055 
4056   /// Returns a read-only iterator that points one past the last
4057   /// handler in the CatchSwitchInst.
4058   handler_iterator handler_end() {
4059     return handler_iterator(op_end(), DerefFnTy(handler_helper));
4060   }
4061 
4062   /// Returns an iterator that points one past the last handler in the
4063   /// CatchSwitchInst.
4064   const_handler_iterator handler_end() const {
4065     return const_handler_iterator(op_end(), ConstDerefFnTy(handler_helper));
4066   }
4067 
4068   /// iteration adapter for range-for loops.
4069   handler_range handlers() {
4070     return make_range(handler_begin(), handler_end());
4071   }
4072 
4073   /// iteration adapter for range-for loops.
4074   const_handler_range handlers() const {
4075     return make_range(handler_begin(), handler_end());
4076   }
4077 
4078   /// Add an entry to the switch instruction...
4079   /// Note:
4080   /// This action invalidates handler_end(). Old handler_end() iterator will
4081   /// point to the added handler.
4082   void addHandler(BasicBlock *Dest);
4083 
4084   void removeHandler(handler_iterator HI);
4085 
4086   unsigned getNumSuccessors() const { return getNumOperands() - 1; }
4087   BasicBlock *getSuccessor(unsigned Idx) const {
4088     assert(Idx < getNumSuccessors() &&
4089            "Successor # out of range for catchswitch!");
4090     return cast<BasicBlock>(getOperand(Idx + 1));
4091   }
4092   void setSuccessor(unsigned Idx, BasicBlock *NewSucc) {
4093     assert(Idx < getNumSuccessors() &&
4094            "Successor # out of range for catchswitch!");
4095     setOperand(Idx + 1, NewSucc);
4096   }
4097 
4098   // Methods for support type inquiry through isa, cast, and dyn_cast:
4099   static bool classof(const Instruction *I) {
4100     return I->getOpcode() == Instruction::CatchSwitch;
4101   }
4102   static bool classof(const Value *V) {
4103     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4104   }
4105 };
4106 
4107 template <>
4108 struct OperandTraits<CatchSwitchInst> : public HungoffOperandTraits<2> {};
4109 
4110 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(CatchSwitchInst, Value)
4111 
4112 //===----------------------------------------------------------------------===//
4113 //                               CleanupPadInst Class
4114 //===----------------------------------------------------------------------===//
4115 class CleanupPadInst : public FuncletPadInst {
4116 private:
4117   explicit CleanupPadInst(Value *ParentPad, ArrayRef<Value *> Args,
4118                           unsigned Values, const Twine &NameStr,
4119                           InsertPosition InsertBefore)
4120       : FuncletPadInst(Instruction::CleanupPad, ParentPad, Args, Values,
4121                        NameStr, InsertBefore) {}
4122 
4123 public:
4124   static CleanupPadInst *Create(Value *ParentPad,
4125                                 ArrayRef<Value *> Args = std::nullopt,
4126                                 const Twine &NameStr = "",
4127                                 InsertPosition InsertBefore = nullptr) {
4128     unsigned Values = 1 + Args.size();
4129     return new (Values)
4130         CleanupPadInst(ParentPad, Args, Values, NameStr, InsertBefore);
4131   }
4132 
4133   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4134   static bool classof(const Instruction *I) {
4135     return I->getOpcode() == Instruction::CleanupPad;
4136   }
4137   static bool classof(const Value *V) {
4138     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4139   }
4140 };
4141 
4142 //===----------------------------------------------------------------------===//
4143 //                               CatchPadInst Class
4144 //===----------------------------------------------------------------------===//
4145 class CatchPadInst : public FuncletPadInst {
4146 private:
4147   explicit CatchPadInst(Value *CatchSwitch, ArrayRef<Value *> Args,
4148                         unsigned Values, const Twine &NameStr,
4149                         InsertPosition InsertBefore)
4150       : FuncletPadInst(Instruction::CatchPad, CatchSwitch, Args, Values,
4151                        NameStr, InsertBefore) {}
4152 
4153 public:
4154   static CatchPadInst *Create(Value *CatchSwitch, ArrayRef<Value *> Args,
4155                               const Twine &NameStr = "",
4156                               InsertPosition InsertBefore = nullptr) {
4157     unsigned Values = 1 + Args.size();
4158     return new (Values)
4159         CatchPadInst(CatchSwitch, Args, Values, NameStr, InsertBefore);
4160   }
4161 
4162   /// Convenience accessors
4163   CatchSwitchInst *getCatchSwitch() const {
4164     return cast<CatchSwitchInst>(Op<-1>());
4165   }
4166   void setCatchSwitch(Value *CatchSwitch) {
4167     assert(CatchSwitch);
4168     Op<-1>() = CatchSwitch;
4169   }
4170 
4171   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4172   static bool classof(const Instruction *I) {
4173     return I->getOpcode() == Instruction::CatchPad;
4174   }
4175   static bool classof(const Value *V) {
4176     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4177   }
4178 };
4179 
4180 //===----------------------------------------------------------------------===//
4181 //                               CatchReturnInst Class
4182 //===----------------------------------------------------------------------===//
4183 
4184 class CatchReturnInst : public Instruction {
4185   CatchReturnInst(const CatchReturnInst &RI);
4186   CatchReturnInst(Value *CatchPad, BasicBlock *BB, InsertPosition InsertBefore);
4187 
4188   void init(Value *CatchPad, BasicBlock *BB);
4189 
4190 protected:
4191   // Note: Instruction needs to be a friend here to call cloneImpl.
4192   friend class Instruction;
4193 
4194   CatchReturnInst *cloneImpl() const;
4195 
4196 public:
4197   static CatchReturnInst *Create(Value *CatchPad, BasicBlock *BB,
4198                                  InsertPosition InsertBefore = nullptr) {
4199     assert(CatchPad);
4200     assert(BB);
4201     return new (2) CatchReturnInst(CatchPad, BB, InsertBefore);
4202   }
4203 
4204   /// Provide fast operand accessors
4205   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
4206 
4207   /// Convenience accessors.
4208   CatchPadInst *getCatchPad() const { return cast<CatchPadInst>(Op<0>()); }
4209   void setCatchPad(CatchPadInst *CatchPad) {
4210     assert(CatchPad);
4211     Op<0>() = CatchPad;
4212   }
4213 
4214   BasicBlock *getSuccessor() const { return cast<BasicBlock>(Op<1>()); }
4215   void setSuccessor(BasicBlock *NewSucc) {
4216     assert(NewSucc);
4217     Op<1>() = NewSucc;
4218   }
4219   unsigned getNumSuccessors() const { return 1; }
4220 
4221   /// Get the parentPad of this catchret's catchpad's catchswitch.
4222   /// The successor block is implicitly a member of this funclet.
4223   Value *getCatchSwitchParentPad() const {
4224     return getCatchPad()->getCatchSwitch()->getParentPad();
4225   }
4226 
4227   // Methods for support type inquiry through isa, cast, and dyn_cast:
4228   static bool classof(const Instruction *I) {
4229     return (I->getOpcode() == Instruction::CatchRet);
4230   }
4231   static bool classof(const Value *V) {
4232     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4233   }
4234 
4235 private:
4236   BasicBlock *getSuccessor(unsigned Idx) const {
4237     assert(Idx < getNumSuccessors() && "Successor # out of range for catchret!");
4238     return getSuccessor();
4239   }
4240 
4241   void setSuccessor(unsigned Idx, BasicBlock *B) {
4242     assert(Idx < getNumSuccessors() && "Successor # out of range for catchret!");
4243     setSuccessor(B);
4244   }
4245 };
4246 
4247 template <>
4248 struct OperandTraits<CatchReturnInst>
4249     : public FixedNumOperandTraits<CatchReturnInst, 2> {};
4250 
4251 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(CatchReturnInst, Value)
4252 
4253 //===----------------------------------------------------------------------===//
4254 //                               CleanupReturnInst Class
4255 //===----------------------------------------------------------------------===//
4256 
4257 class CleanupReturnInst : public Instruction {
4258   using UnwindDestField = BoolBitfieldElementT<0>;
4259 
4260 private:
4261   CleanupReturnInst(const CleanupReturnInst &RI);
4262   CleanupReturnInst(Value *CleanupPad, BasicBlock *UnwindBB, unsigned Values,
4263                     InsertPosition InsertBefore = nullptr);
4264 
4265   void init(Value *CleanupPad, BasicBlock *UnwindBB);
4266 
4267 protected:
4268   // Note: Instruction needs to be a friend here to call cloneImpl.
4269   friend class Instruction;
4270 
4271   CleanupReturnInst *cloneImpl() const;
4272 
4273 public:
4274   static CleanupReturnInst *Create(Value *CleanupPad,
4275                                    BasicBlock *UnwindBB = nullptr,
4276                                    InsertPosition InsertBefore = nullptr) {
4277     assert(CleanupPad);
4278     unsigned Values = 1;
4279     if (UnwindBB)
4280       ++Values;
4281     return new (Values)
4282         CleanupReturnInst(CleanupPad, UnwindBB, Values, InsertBefore);
4283   }
4284 
4285   /// Provide fast operand accessors
4286   DECLARE_TRANSPARENT_OPERAND_ACCESSORS(Value);
4287 
4288   bool hasUnwindDest() const { return getSubclassData<UnwindDestField>(); }
4289   bool unwindsToCaller() const { return !hasUnwindDest(); }
4290 
4291   /// Convenience accessor.
4292   CleanupPadInst *getCleanupPad() const {
4293     return cast<CleanupPadInst>(Op<0>());
4294   }
4295   void setCleanupPad(CleanupPadInst *CleanupPad) {
4296     assert(CleanupPad);
4297     Op<0>() = CleanupPad;
4298   }
4299 
4300   unsigned getNumSuccessors() const { return hasUnwindDest() ? 1 : 0; }
4301 
4302   BasicBlock *getUnwindDest() const {
4303     return hasUnwindDest() ? cast<BasicBlock>(Op<1>()) : nullptr;
4304   }
4305   void setUnwindDest(BasicBlock *NewDest) {
4306     assert(NewDest);
4307     assert(hasUnwindDest());
4308     Op<1>() = NewDest;
4309   }
4310 
4311   // Methods for support type inquiry through isa, cast, and dyn_cast:
4312   static bool classof(const Instruction *I) {
4313     return (I->getOpcode() == Instruction::CleanupRet);
4314   }
4315   static bool classof(const Value *V) {
4316     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4317   }
4318 
4319 private:
4320   BasicBlock *getSuccessor(unsigned Idx) const {
4321     assert(Idx == 0);
4322     return getUnwindDest();
4323   }
4324 
4325   void setSuccessor(unsigned Idx, BasicBlock *B) {
4326     assert(Idx == 0);
4327     setUnwindDest(B);
4328   }
4329 
4330   // Shadow Instruction::setInstructionSubclassData with a private forwarding
4331   // method so that subclasses cannot accidentally use it.
4332   template <typename Bitfield>
4333   void setSubclassData(typename Bitfield::Type Value) {
4334     Instruction::setSubclassData<Bitfield>(Value);
4335   }
4336 };
4337 
4338 template <>
4339 struct OperandTraits<CleanupReturnInst>
4340     : public VariadicOperandTraits<CleanupReturnInst, /*MINARITY=*/1> {};
4341 
4342 DEFINE_TRANSPARENT_OPERAND_ACCESSORS(CleanupReturnInst, Value)
4343 
4344 //===----------------------------------------------------------------------===//
4345 //                           UnreachableInst Class
4346 //===----------------------------------------------------------------------===//
4347 
4348 //===---------------------------------------------------------------------------
4349 /// This function has undefined behavior.  In particular, the
4350 /// presence of this instruction indicates some higher level knowledge that the
4351 /// end of the block cannot be reached.
4352 ///
4353 class UnreachableInst : public Instruction {
4354 protected:
4355   // Note: Instruction needs to be a friend here to call cloneImpl.
4356   friend class Instruction;
4357 
4358   UnreachableInst *cloneImpl() const;
4359 
4360 public:
4361   explicit UnreachableInst(LLVMContext &C,
4362                            InsertPosition InsertBefore = nullptr);
4363 
4364   // allocate space for exactly zero operands
4365   void *operator new(size_t S) { return User::operator new(S, 0); }
4366   void operator delete(void *Ptr) { User::operator delete(Ptr); }
4367 
4368   unsigned getNumSuccessors() const { return 0; }
4369 
4370   // Methods for support type inquiry through isa, cast, and dyn_cast:
4371   static bool classof(const Instruction *I) {
4372     return I->getOpcode() == Instruction::Unreachable;
4373   }
4374   static bool classof(const Value *V) {
4375     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4376   }
4377 
4378 private:
4379   BasicBlock *getSuccessor(unsigned idx) const {
4380     llvm_unreachable("UnreachableInst has no successors!");
4381   }
4382 
4383   void setSuccessor(unsigned idx, BasicBlock *B) {
4384     llvm_unreachable("UnreachableInst has no successors!");
4385   }
4386 };
4387 
4388 //===----------------------------------------------------------------------===//
4389 //                                 TruncInst Class
4390 //===----------------------------------------------------------------------===//
4391 
4392 /// This class represents a truncation of integer types.
4393 class TruncInst : public CastInst {
4394 protected:
4395   // Note: Instruction needs to be a friend here to call cloneImpl.
4396   friend class Instruction;
4397 
4398   /// Clone an identical TruncInst
4399   TruncInst *cloneImpl() const;
4400 
4401 public:
4402   enum { AnyWrap = 0, NoUnsignedWrap = (1 << 0), NoSignedWrap = (1 << 1) };
4403 
4404   /// Constructor with insert-before-instruction semantics
4405   TruncInst(Value *S,                  ///< The value to be truncated
4406             Type *Ty,                  ///< The (smaller) type to truncate to
4407             const Twine &NameStr = "", ///< A name for the new instruction
4408             InsertPosition InsertBefore =
4409                 nullptr ///< Where to insert the new instruction
4410   );
4411 
4412   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4413   static bool classof(const Instruction *I) {
4414     return I->getOpcode() == Trunc;
4415   }
4416   static bool classof(const Value *V) {
4417     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4418   }
4419 
4420   void setHasNoUnsignedWrap(bool B) {
4421     SubclassOptionalData =
4422         (SubclassOptionalData & ~NoUnsignedWrap) | (B * NoUnsignedWrap);
4423   }
4424   void setHasNoSignedWrap(bool B) {
4425     SubclassOptionalData =
4426         (SubclassOptionalData & ~NoSignedWrap) | (B * NoSignedWrap);
4427   }
4428 
4429   /// Test whether this operation is known to never
4430   /// undergo unsigned overflow, aka the nuw property.
4431   bool hasNoUnsignedWrap() const {
4432     return SubclassOptionalData & NoUnsignedWrap;
4433   }
4434 
4435   /// Test whether this operation is known to never
4436   /// undergo signed overflow, aka the nsw property.
4437   bool hasNoSignedWrap() const {
4438     return (SubclassOptionalData & NoSignedWrap) != 0;
4439   }
4440 
4441   /// Returns the no-wrap kind of the operation.
4442   unsigned getNoWrapKind() const {
4443     unsigned NoWrapKind = 0;
4444     if (hasNoUnsignedWrap())
4445       NoWrapKind |= NoUnsignedWrap;
4446 
4447     if (hasNoSignedWrap())
4448       NoWrapKind |= NoSignedWrap;
4449 
4450     return NoWrapKind;
4451   }
4452 };
4453 
4454 //===----------------------------------------------------------------------===//
4455 //                                 ZExtInst Class
4456 //===----------------------------------------------------------------------===//
4457 
4458 /// This class represents zero extension of integer types.
4459 class ZExtInst : public CastInst {
4460 protected:
4461   // Note: Instruction needs to be a friend here to call cloneImpl.
4462   friend class Instruction;
4463 
4464   /// Clone an identical ZExtInst
4465   ZExtInst *cloneImpl() const;
4466 
4467 public:
4468   /// Constructor with insert-before-instruction semantics
4469   ZExtInst(Value *S,                  ///< The value to be zero extended
4470            Type *Ty,                  ///< The type to zero extend to
4471            const Twine &NameStr = "", ///< A name for the new instruction
4472            InsertPosition InsertBefore =
4473                nullptr ///< Where to insert the new instruction
4474   );
4475 
4476   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4477   static bool classof(const Instruction *I) {
4478     return I->getOpcode() == ZExt;
4479   }
4480   static bool classof(const Value *V) {
4481     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4482   }
4483 };
4484 
4485 //===----------------------------------------------------------------------===//
4486 //                                 SExtInst Class
4487 //===----------------------------------------------------------------------===//
4488 
4489 /// This class represents a sign extension of integer types.
4490 class SExtInst : public CastInst {
4491 protected:
4492   // Note: Instruction needs to be a friend here to call cloneImpl.
4493   friend class Instruction;
4494 
4495   /// Clone an identical SExtInst
4496   SExtInst *cloneImpl() const;
4497 
4498 public:
4499   /// Constructor with insert-before-instruction semantics
4500   SExtInst(Value *S,                  ///< The value to be sign extended
4501            Type *Ty,                  ///< The type to sign extend to
4502            const Twine &NameStr = "", ///< A name for the new instruction
4503            InsertPosition InsertBefore =
4504                nullptr ///< Where to insert the new instruction
4505   );
4506 
4507   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4508   static bool classof(const Instruction *I) {
4509     return I->getOpcode() == SExt;
4510   }
4511   static bool classof(const Value *V) {
4512     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4513   }
4514 };
4515 
4516 //===----------------------------------------------------------------------===//
4517 //                                 FPTruncInst Class
4518 //===----------------------------------------------------------------------===//
4519 
4520 /// This class represents a truncation of floating point types.
4521 class FPTruncInst : public CastInst {
4522 protected:
4523   // Note: Instruction needs to be a friend here to call cloneImpl.
4524   friend class Instruction;
4525 
4526   /// Clone an identical FPTruncInst
4527   FPTruncInst *cloneImpl() const;
4528 
4529 public:                 /// Constructor with insert-before-instruction semantics
4530   FPTruncInst(Value *S, ///< The value to be truncated
4531               Type *Ty, ///< The type to truncate to
4532               const Twine &NameStr = "", ///< A name for the new instruction
4533               InsertPosition InsertBefore =
4534                   nullptr ///< Where to insert the new instruction
4535   );
4536 
4537   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4538   static bool classof(const Instruction *I) {
4539     return I->getOpcode() == FPTrunc;
4540   }
4541   static bool classof(const Value *V) {
4542     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4543   }
4544 };
4545 
4546 //===----------------------------------------------------------------------===//
4547 //                                 FPExtInst Class
4548 //===----------------------------------------------------------------------===//
4549 
4550 /// This class represents an extension of floating point types.
4551 class FPExtInst : public CastInst {
4552 protected:
4553   // Note: Instruction needs to be a friend here to call cloneImpl.
4554   friend class Instruction;
4555 
4556   /// Clone an identical FPExtInst
4557   FPExtInst *cloneImpl() const;
4558 
4559 public:
4560   /// Constructor with insert-before-instruction semantics
4561   FPExtInst(Value *S,                  ///< The value to be extended
4562             Type *Ty,                  ///< The type to extend to
4563             const Twine &NameStr = "", ///< A name for the new instruction
4564             InsertPosition InsertBefore =
4565                 nullptr ///< Where to insert the new instruction
4566   );
4567 
4568   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4569   static bool classof(const Instruction *I) {
4570     return I->getOpcode() == FPExt;
4571   }
4572   static bool classof(const Value *V) {
4573     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4574   }
4575 };
4576 
4577 //===----------------------------------------------------------------------===//
4578 //                                 UIToFPInst Class
4579 //===----------------------------------------------------------------------===//
4580 
4581 /// This class represents a cast unsigned integer to floating point.
4582 class UIToFPInst : public CastInst {
4583 protected:
4584   // Note: Instruction needs to be a friend here to call cloneImpl.
4585   friend class Instruction;
4586 
4587   /// Clone an identical UIToFPInst
4588   UIToFPInst *cloneImpl() const;
4589 
4590 public:
4591   /// Constructor with insert-before-instruction semantics
4592   UIToFPInst(Value *S,                  ///< The value to be converted
4593              Type *Ty,                  ///< The type to convert to
4594              const Twine &NameStr = "", ///< A name for the new instruction
4595              InsertPosition InsertBefore =
4596                  nullptr ///< Where to insert the new instruction
4597   );
4598 
4599   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4600   static bool classof(const Instruction *I) {
4601     return I->getOpcode() == UIToFP;
4602   }
4603   static bool classof(const Value *V) {
4604     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4605   }
4606 };
4607 
4608 //===----------------------------------------------------------------------===//
4609 //                                 SIToFPInst Class
4610 //===----------------------------------------------------------------------===//
4611 
4612 /// This class represents a cast from signed integer to floating point.
4613 class SIToFPInst : public CastInst {
4614 protected:
4615   // Note: Instruction needs to be a friend here to call cloneImpl.
4616   friend class Instruction;
4617 
4618   /// Clone an identical SIToFPInst
4619   SIToFPInst *cloneImpl() const;
4620 
4621 public:
4622   /// Constructor with insert-before-instruction semantics
4623   SIToFPInst(Value *S,                  ///< The value to be converted
4624              Type *Ty,                  ///< The type to convert to
4625              const Twine &NameStr = "", ///< A name for the new instruction
4626              InsertPosition InsertBefore =
4627                  nullptr ///< Where to insert the new instruction
4628   );
4629 
4630   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4631   static bool classof(const Instruction *I) {
4632     return I->getOpcode() == SIToFP;
4633   }
4634   static bool classof(const Value *V) {
4635     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4636   }
4637 };
4638 
4639 //===----------------------------------------------------------------------===//
4640 //                                 FPToUIInst Class
4641 //===----------------------------------------------------------------------===//
4642 
4643 /// This class represents a cast from floating point to unsigned integer
4644 class FPToUIInst  : public CastInst {
4645 protected:
4646   // Note: Instruction needs to be a friend here to call cloneImpl.
4647   friend class Instruction;
4648 
4649   /// Clone an identical FPToUIInst
4650   FPToUIInst *cloneImpl() const;
4651 
4652 public:
4653   /// Constructor with insert-before-instruction semantics
4654   FPToUIInst(Value *S,                  ///< The value to be converted
4655              Type *Ty,                  ///< The type to convert to
4656              const Twine &NameStr = "", ///< A name for the new instruction
4657              InsertPosition InsertBefore =
4658                  nullptr ///< Where to insert the new instruction
4659   );
4660 
4661   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4662   static bool classof(const Instruction *I) {
4663     return I->getOpcode() == FPToUI;
4664   }
4665   static bool classof(const Value *V) {
4666     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4667   }
4668 };
4669 
4670 //===----------------------------------------------------------------------===//
4671 //                                 FPToSIInst Class
4672 //===----------------------------------------------------------------------===//
4673 
4674 /// This class represents a cast from floating point to signed integer.
4675 class FPToSIInst  : public CastInst {
4676 protected:
4677   // Note: Instruction needs to be a friend here to call cloneImpl.
4678   friend class Instruction;
4679 
4680   /// Clone an identical FPToSIInst
4681   FPToSIInst *cloneImpl() const;
4682 
4683 public:
4684   /// Constructor with insert-before-instruction semantics
4685   FPToSIInst(Value *S,                  ///< The value to be converted
4686              Type *Ty,                  ///< The type to convert to
4687              const Twine &NameStr = "", ///< A name for the new instruction
4688              InsertPosition InsertBefore =
4689                  nullptr ///< Where to insert the new instruction
4690   );
4691 
4692   /// Methods for support type inquiry through isa, cast, and dyn_cast:
4693   static bool classof(const Instruction *I) {
4694     return I->getOpcode() == FPToSI;
4695   }
4696   static bool classof(const Value *V) {
4697     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4698   }
4699 };
4700 
4701 //===----------------------------------------------------------------------===//
4702 //                                 IntToPtrInst Class
4703 //===----------------------------------------------------------------------===//
4704 
4705 /// This class represents a cast from an integer to a pointer.
4706 class IntToPtrInst : public CastInst {
4707 public:
4708   // Note: Instruction needs to be a friend here to call cloneImpl.
4709   friend class Instruction;
4710 
4711   /// Constructor with insert-before-instruction semantics
4712   IntToPtrInst(Value *S,                  ///< The value to be converted
4713                Type *Ty,                  ///< The type to convert to
4714                const Twine &NameStr = "", ///< A name for the new instruction
4715                InsertPosition InsertBefore =
4716                    nullptr ///< Where to insert the new instruction
4717   );
4718 
4719   /// Clone an identical IntToPtrInst.
4720   IntToPtrInst *cloneImpl() const;
4721 
4722   /// Returns the address space of this instruction's pointer type.
4723   unsigned getAddressSpace() const {
4724     return getType()->getPointerAddressSpace();
4725   }
4726 
4727   // Methods for support type inquiry through isa, cast, and dyn_cast:
4728   static bool classof(const Instruction *I) {
4729     return I->getOpcode() == IntToPtr;
4730   }
4731   static bool classof(const Value *V) {
4732     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4733   }
4734 };
4735 
4736 //===----------------------------------------------------------------------===//
4737 //                                 PtrToIntInst Class
4738 //===----------------------------------------------------------------------===//
4739 
4740 /// This class represents a cast from a pointer to an integer.
4741 class PtrToIntInst : public CastInst {
4742 protected:
4743   // Note: Instruction needs to be a friend here to call cloneImpl.
4744   friend class Instruction;
4745 
4746   /// Clone an identical PtrToIntInst.
4747   PtrToIntInst *cloneImpl() const;
4748 
4749 public:
4750   /// Constructor with insert-before-instruction semantics
4751   PtrToIntInst(Value *S,                  ///< The value to be converted
4752                Type *Ty,                  ///< The type to convert to
4753                const Twine &NameStr = "", ///< A name for the new instruction
4754                InsertPosition InsertBefore =
4755                    nullptr ///< Where to insert the new instruction
4756   );
4757 
4758   /// Gets the pointer operand.
4759   Value *getPointerOperand() { return getOperand(0); }
4760   /// Gets the pointer operand.
4761   const Value *getPointerOperand() const { return getOperand(0); }
4762   /// Gets the operand index of the pointer operand.
4763   static unsigned getPointerOperandIndex() { return 0U; }
4764 
4765   /// Returns the address space of the pointer operand.
4766   unsigned getPointerAddressSpace() const {
4767     return getPointerOperand()->getType()->getPointerAddressSpace();
4768   }
4769 
4770   // Methods for support type inquiry through isa, cast, and dyn_cast:
4771   static bool classof(const Instruction *I) {
4772     return I->getOpcode() == PtrToInt;
4773   }
4774   static bool classof(const Value *V) {
4775     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4776   }
4777 };
4778 
4779 //===----------------------------------------------------------------------===//
4780 //                             BitCastInst Class
4781 //===----------------------------------------------------------------------===//
4782 
4783 /// This class represents a no-op cast from one type to another.
4784 class BitCastInst : public CastInst {
4785 protected:
4786   // Note: Instruction needs to be a friend here to call cloneImpl.
4787   friend class Instruction;
4788 
4789   /// Clone an identical BitCastInst.
4790   BitCastInst *cloneImpl() const;
4791 
4792 public:
4793   /// Constructor with insert-before-instruction semantics
4794   BitCastInst(Value *S,                  ///< The value to be casted
4795               Type *Ty,                  ///< The type to casted to
4796               const Twine &NameStr = "", ///< A name for the new instruction
4797               InsertPosition InsertBefore =
4798                   nullptr ///< Where to insert the new instruction
4799   );
4800 
4801   // Methods for support type inquiry through isa, cast, and dyn_cast:
4802   static bool classof(const Instruction *I) {
4803     return I->getOpcode() == BitCast;
4804   }
4805   static bool classof(const Value *V) {
4806     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4807   }
4808 };
4809 
4810 //===----------------------------------------------------------------------===//
4811 //                          AddrSpaceCastInst Class
4812 //===----------------------------------------------------------------------===//
4813 
4814 /// This class represents a conversion between pointers from one address space
4815 /// to another.
4816 class AddrSpaceCastInst : public CastInst {
4817 protected:
4818   // Note: Instruction needs to be a friend here to call cloneImpl.
4819   friend class Instruction;
4820 
4821   /// Clone an identical AddrSpaceCastInst.
4822   AddrSpaceCastInst *cloneImpl() const;
4823 
4824 public:
4825   /// Constructor with insert-before-instruction semantics
4826   AddrSpaceCastInst(
4827       Value *S,                  ///< The value to be casted
4828       Type *Ty,                  ///< The type to casted to
4829       const Twine &NameStr = "", ///< A name for the new instruction
4830       InsertPosition InsertBefore =
4831           nullptr ///< Where to insert the new instruction
4832   );
4833 
4834   // Methods for support type inquiry through isa, cast, and dyn_cast:
4835   static bool classof(const Instruction *I) {
4836     return I->getOpcode() == AddrSpaceCast;
4837   }
4838   static bool classof(const Value *V) {
4839     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4840   }
4841 
4842   /// Gets the pointer operand.
4843   Value *getPointerOperand() {
4844     return getOperand(0);
4845   }
4846 
4847   /// Gets the pointer operand.
4848   const Value *getPointerOperand() const {
4849     return getOperand(0);
4850   }
4851 
4852   /// Gets the operand index of the pointer operand.
4853   static unsigned getPointerOperandIndex() {
4854     return 0U;
4855   }
4856 
4857   /// Returns the address space of the pointer operand.
4858   unsigned getSrcAddressSpace() const {
4859     return getPointerOperand()->getType()->getPointerAddressSpace();
4860   }
4861 
4862   /// Returns the address space of the result.
4863   unsigned getDestAddressSpace() const {
4864     return getType()->getPointerAddressSpace();
4865   }
4866 };
4867 
4868 //===----------------------------------------------------------------------===//
4869 //                          Helper functions
4870 //===----------------------------------------------------------------------===//
4871 
4872 /// A helper function that returns the pointer operand of a load or store
4873 /// instruction. Returns nullptr if not load or store.
4874 inline const Value *getLoadStorePointerOperand(const Value *V) {
4875   if (auto *Load = dyn_cast<LoadInst>(V))
4876     return Load->getPointerOperand();
4877   if (auto *Store = dyn_cast<StoreInst>(V))
4878     return Store->getPointerOperand();
4879   return nullptr;
4880 }
4881 inline Value *getLoadStorePointerOperand(Value *V) {
4882   return const_cast<Value *>(
4883       getLoadStorePointerOperand(static_cast<const Value *>(V)));
4884 }
4885 
4886 /// A helper function that returns the pointer operand of a load, store
4887 /// or GEP instruction. Returns nullptr if not load, store, or GEP.
4888 inline const Value *getPointerOperand(const Value *V) {
4889   if (auto *Ptr = getLoadStorePointerOperand(V))
4890     return Ptr;
4891   if (auto *Gep = dyn_cast<GetElementPtrInst>(V))
4892     return Gep->getPointerOperand();
4893   return nullptr;
4894 }
4895 inline Value *getPointerOperand(Value *V) {
4896   return const_cast<Value *>(getPointerOperand(static_cast<const Value *>(V)));
4897 }
4898 
4899 /// A helper function that returns the alignment of load or store instruction.
4900 inline Align getLoadStoreAlignment(Value *I) {
4901   assert((isa<LoadInst>(I) || isa<StoreInst>(I)) &&
4902          "Expected Load or Store instruction");
4903   if (auto *LI = dyn_cast<LoadInst>(I))
4904     return LI->getAlign();
4905   return cast<StoreInst>(I)->getAlign();
4906 }
4907 
4908 /// A helper function that returns the address space of the pointer operand of
4909 /// load or store instruction.
4910 inline unsigned getLoadStoreAddressSpace(Value *I) {
4911   assert((isa<LoadInst>(I) || isa<StoreInst>(I)) &&
4912          "Expected Load or Store instruction");
4913   if (auto *LI = dyn_cast<LoadInst>(I))
4914     return LI->getPointerAddressSpace();
4915   return cast<StoreInst>(I)->getPointerAddressSpace();
4916 }
4917 
4918 /// A helper function that returns the type of a load or store instruction.
4919 inline Type *getLoadStoreType(Value *I) {
4920   assert((isa<LoadInst>(I) || isa<StoreInst>(I)) &&
4921          "Expected Load or Store instruction");
4922   if (auto *LI = dyn_cast<LoadInst>(I))
4923     return LI->getType();
4924   return cast<StoreInst>(I)->getValueOperand()->getType();
4925 }
4926 
4927 /// A helper function that returns an atomic operation's sync scope; returns
4928 /// std::nullopt if it is not an atomic operation.
4929 inline std::optional<SyncScope::ID> getAtomicSyncScopeID(const Instruction *I) {
4930   if (!I->isAtomic())
4931     return std::nullopt;
4932   if (auto *AI = dyn_cast<LoadInst>(I))
4933     return AI->getSyncScopeID();
4934   if (auto *AI = dyn_cast<StoreInst>(I))
4935     return AI->getSyncScopeID();
4936   if (auto *AI = dyn_cast<FenceInst>(I))
4937     return AI->getSyncScopeID();
4938   if (auto *AI = dyn_cast<AtomicCmpXchgInst>(I))
4939     return AI->getSyncScopeID();
4940   if (auto *AI = dyn_cast<AtomicRMWInst>(I))
4941     return AI->getSyncScopeID();
4942   llvm_unreachable("unhandled atomic operation");
4943 }
4944 
4945 //===----------------------------------------------------------------------===//
4946 //                              FreezeInst Class
4947 //===----------------------------------------------------------------------===//
4948 
4949 /// This class represents a freeze function that returns random concrete
4950 /// value if an operand is either a poison value or an undef value
4951 class FreezeInst : public UnaryInstruction {
4952 protected:
4953   // Note: Instruction needs to be a friend here to call cloneImpl.
4954   friend class Instruction;
4955 
4956   /// Clone an identical FreezeInst
4957   FreezeInst *cloneImpl() const;
4958 
4959 public:
4960   explicit FreezeInst(Value *S, const Twine &NameStr = "",
4961                       InsertPosition InsertBefore = nullptr);
4962 
4963   // Methods for support type inquiry through isa, cast, and dyn_cast:
4964   static inline bool classof(const Instruction *I) {
4965     return I->getOpcode() == Freeze;
4966   }
4967   static inline bool classof(const Value *V) {
4968     return isa<Instruction>(V) && classof(cast<Instruction>(V));
4969   }
4970 };
4971 
4972 } // end namespace llvm
4973 
4974 #endif // LLVM_IR_INSTRUCTIONS_H
4975