LLVM  6.0.0svn
ConstantFold.h
Go to the documentation of this file.
1 //===-- ConstantFolding.h - Internal Constant Folding Interface -*- C++ -*-===//
2 //
3 // The LLVM Compiler Infrastructure
4 //
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
7 //
8 //===----------------------------------------------------------------------===//
9 //
10 // This file defines the (internal) constant folding interfaces for LLVM. These
11 // interfaces are used by the ConstantExpr::get* methods to automatically fold
12 // constants when possible.
13 //
14 // These operators may return a null object if they don't know how to perform
15 // the specified operation on the specified constant types.
16 //
17 //===----------------------------------------------------------------------===//
18 
19 #ifndef LLVM_LIB_IR_CONSTANTFOLD_H
20 #define LLVM_LIB_IR_CONSTANTFOLD_H
21 
22 #include "llvm/ADT/Optional.h"
23 
24 namespace llvm {
25 template <typename T> class ArrayRef;
26  class Value;
27  class Constant;
28  class Type;
29 
30  // Constant fold various types of instruction...
32  unsigned opcode, ///< The opcode of the cast
33  Constant *V, ///< The source constant
34  Type *DestTy ///< The destination type
35  );
37  Constant *V1, Constant *V2);
40  Constant *Idx);
42  Constant *Mask);
44  ArrayRef<unsigned> Idxs);
46  ArrayRef<unsigned> Idxs);
47  Constant *ConstantFoldBinaryInstruction(unsigned Opcode, Constant *V1,
48  Constant *V2);
49  Constant *ConstantFoldCompareInstruction(unsigned short predicate,
50  Constant *C1, Constant *C2);
51  Constant *ConstantFoldGetElementPtr(Type *Ty, Constant *C, bool InBounds,
52  Optional<unsigned> InRangeIndex,
53  ArrayRef<Value *> Idxs);
54 } // End llvm namespace
55 
56 #endif
uint64_t CallInst * C
Compute iterated dominance frontiers using a linear time algorithm.
Definition: AllocatorList.h:24
Constant * ConstantFoldExtractElementInstruction(Constant *Val, Constant *Idx)
Attempt to constant fold an extractelement instruction with the specified operands and indices...
Constant * ConstantFoldCastInstruction(unsigned opcode, Constant *V, Type *DestTy)
Constant * ConstantFoldInsertValueInstruction(Constant *Agg, Constant *Val, ArrayRef< unsigned > Idxs)
ConstantFoldInsertValueInstruction - Attempt to constant fold an insertvalue instruction with the spe...
Constant * ConstantFoldShuffleVectorInstruction(Constant *V1, Constant *V2, Constant *Mask)
Attempt to constant fold a shufflevector instruction with the specified operands and indices...
Constant * ConstantFoldBinaryInstruction(unsigned Opcode, Constant *V1, Constant *V2)
Constant * ConstantFoldCompareInstruction(unsigned short predicate, Constant *C1, Constant *C2)
Constant * ConstantFoldSelectInstruction(Constant *Cond, Constant *V1, Constant *V2)
Attempt to constant fold a select instruction with the specified operands.
Constant * ConstantFoldInsertElementInstruction(Constant *Val, Constant *Elt, Constant *Idx)
Attempt to constant fold an insertelement instruction with the specified operands and indices...
Constant * ConstantFoldGetElementPtr(Type *Ty, Constant *C, bool InBounds, Optional< unsigned > InRangeIndex, ArrayRef< Value *> Idxs)
std::underlying_type< E >::type Mask()
Get a bitmask with 1s in all places up to the high-order bit of E&#39;s largest value.
Definition: BitmaskEnum.h:81
Constant * ConstantFoldExtractValueInstruction(Constant *Agg, ArrayRef< unsigned > Idxs)
Attempt to constant fold an extractvalue instruction with the specified operands and indices...