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