LLVM API Documentation

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
TargetFolder.h
Go to the documentation of this file.
1 //====-- llvm/Support/TargetFolder.h - Constant folding helper -*- 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 TargetFolder class, a helper for IRBuilder.
11 // It provides IRBuilder with a set of methods for creating constants with
12 // target dependent folding, in addition to the same target-independent
13 // folding that the ConstantFolder class provides. For general constant
14 // creation and folding, use ConstantExpr and the routines in
15 // llvm/Analysis/ConstantFolding.h.
16 //
17 //===----------------------------------------------------------------------===//
18 
19 #ifndef LLVM_SUPPORT_TARGETFOLDER_H
20 #define LLVM_SUPPORT_TARGETFOLDER_H
21 
22 #include "llvm/ADT/ArrayRef.h"
24 #include "llvm/IR/Constants.h"
25 #include "llvm/IR/InstrTypes.h"
26 
27 namespace llvm {
28 
29 class DataLayout;
30 
31 /// TargetFolder - Create constants with target dependent folding.
32 class TargetFolder {
33  const DataLayout *TD;
34 
35  /// Fold - Fold the constant using target specific information.
36  Constant *Fold(Constant *C) const {
37  if (ConstantExpr *CE = dyn_cast<ConstantExpr>(C))
38  if (Constant *CF = ConstantFoldConstantExpression(CE, TD))
39  return CF;
40  return C;
41  }
42 
43 public:
44  explicit TargetFolder(const DataLayout *TheTD) : TD(TheTD) {}
45 
46  //===--------------------------------------------------------------------===//
47  // Binary Operators
48  //===--------------------------------------------------------------------===//
49 
51  bool HasNUW = false, bool HasNSW = false) const {
52  return Fold(ConstantExpr::getAdd(LHS, RHS, HasNUW, HasNSW));
53  }
54  Constant *CreateFAdd(Constant *LHS, Constant *RHS) const {
55  return Fold(ConstantExpr::getFAdd(LHS, RHS));
56  }
58  bool HasNUW = false, bool HasNSW = false) const {
59  return Fold(ConstantExpr::getSub(LHS, RHS, HasNUW, HasNSW));
60  }
61  Constant *CreateFSub(Constant *LHS, Constant *RHS) const {
62  return Fold(ConstantExpr::getFSub(LHS, RHS));
63  }
65  bool HasNUW = false, bool HasNSW = false) const {
66  return Fold(ConstantExpr::getMul(LHS, RHS, HasNUW, HasNSW));
67  }
68  Constant *CreateFMul(Constant *LHS, Constant *RHS) const {
69  return Fold(ConstantExpr::getFMul(LHS, RHS));
70  }
71  Constant *CreateUDiv(Constant *LHS, Constant *RHS, bool isExact = false)const{
72  return Fold(ConstantExpr::getUDiv(LHS, RHS, isExact));
73  }
74  Constant *CreateSDiv(Constant *LHS, Constant *RHS, bool isExact = false)const{
75  return Fold(ConstantExpr::getSDiv(LHS, RHS, isExact));
76  }
77  Constant *CreateFDiv(Constant *LHS, Constant *RHS) const {
78  return Fold(ConstantExpr::getFDiv(LHS, RHS));
79  }
80  Constant *CreateURem(Constant *LHS, Constant *RHS) const {
81  return Fold(ConstantExpr::getURem(LHS, RHS));
82  }
83  Constant *CreateSRem(Constant *LHS, Constant *RHS) const {
84  return Fold(ConstantExpr::getSRem(LHS, RHS));
85  }
86  Constant *CreateFRem(Constant *LHS, Constant *RHS) const {
87  return Fold(ConstantExpr::getFRem(LHS, RHS));
88  }
90  bool HasNUW = false, bool HasNSW = false) const {
91  return Fold(ConstantExpr::getShl(LHS, RHS, HasNUW, HasNSW));
92  }
93  Constant *CreateLShr(Constant *LHS, Constant *RHS, bool isExact = false)const{
94  return Fold(ConstantExpr::getLShr(LHS, RHS, isExact));
95  }
96  Constant *CreateAShr(Constant *LHS, Constant *RHS, bool isExact = false)const{
97  return Fold(ConstantExpr::getAShr(LHS, RHS, isExact));
98  }
99  Constant *CreateAnd(Constant *LHS, Constant *RHS) const {
100  return Fold(ConstantExpr::getAnd(LHS, RHS));
101  }
102  Constant *CreateOr(Constant *LHS, Constant *RHS) const {
103  return Fold(ConstantExpr::getOr(LHS, RHS));
104  }
105  Constant *CreateXor(Constant *LHS, Constant *RHS) const {
106  return Fold(ConstantExpr::getXor(LHS, RHS));
107  }
108 
110  Constant *LHS, Constant *RHS) const {
111  return Fold(ConstantExpr::get(Opc, LHS, RHS));
112  }
113 
114  //===--------------------------------------------------------------------===//
115  // Unary Operators
116  //===--------------------------------------------------------------------===//
117 
119  bool HasNUW = false, bool HasNSW = false) const {
120  return Fold(ConstantExpr::getNeg(C, HasNUW, HasNSW));
121  }
123  return Fold(ConstantExpr::getFNeg(C));
124  }
126  return Fold(ConstantExpr::getNot(C));
127  }
128 
129  //===--------------------------------------------------------------------===//
130  // Memory Instructions
131  //===--------------------------------------------------------------------===//
132 
134  ArrayRef<Constant *> IdxList) const {
135  return Fold(ConstantExpr::getGetElementPtr(C, IdxList));
136  }
138  // This form of the function only exists to avoid ambiguous overload
139  // warnings about whether to convert Idx to ArrayRef<Constant *> or
140  // ArrayRef<Value *>.
141  return Fold(ConstantExpr::getGetElementPtr(C, Idx));
142  }
144  ArrayRef<Value *> IdxList) const {
145  return Fold(ConstantExpr::getGetElementPtr(C, IdxList));
146  }
147 
149  ArrayRef<Constant *> IdxList) const {
150  return Fold(ConstantExpr::getInBoundsGetElementPtr(C, IdxList));
151  }
153  // This form of the function only exists to avoid ambiguous overload
154  // warnings about whether to convert Idx to ArrayRef<Constant *> or
155  // ArrayRef<Value *>.
156  return Fold(ConstantExpr::getInBoundsGetElementPtr(C, Idx));
157  }
159  ArrayRef<Value *> IdxList) const {
160  return Fold(ConstantExpr::getInBoundsGetElementPtr(C, IdxList));
161  }
162 
163  //===--------------------------------------------------------------------===//
164  // Cast/Conversion Operators
165  //===--------------------------------------------------------------------===//
166 
168  Type *DestTy) const {
169  if (C->getType() == DestTy)
170  return C; // avoid calling Fold
171  return Fold(ConstantExpr::getCast(Op, C, DestTy));
172  }
174  bool isSigned) const {
175  if (C->getType() == DestTy)
176  return C; // avoid calling Fold
177  return Fold(ConstantExpr::getIntegerCast(C, DestTy, isSigned));
178  }
179  Constant *CreatePointerCast(Constant *C, Type *DestTy) const {
180  if (C->getType() == DestTy)
181  return C; // avoid calling Fold
182  return Fold(ConstantExpr::getPointerCast(C, DestTy));
183  }
184  Constant *CreateFPCast(Constant *C, Type *DestTy) const {
185  if (C->getType() == DestTy)
186  return C; // avoid calling Fold
187  return Fold(ConstantExpr::getFPCast(C, DestTy));
188  }
189  Constant *CreateBitCast(Constant *C, Type *DestTy) const {
190  return CreateCast(Instruction::BitCast, C, DestTy);
191  }
192  Constant *CreateIntToPtr(Constant *C, Type *DestTy) const {
193  return CreateCast(Instruction::IntToPtr, C, DestTy);
194  }
195  Constant *CreatePtrToInt(Constant *C, Type *DestTy) const {
196  return CreateCast(Instruction::PtrToInt, C, DestTy);
197  }
199  if (C->getType() == DestTy)
200  return C; // avoid calling Fold
201  return Fold(ConstantExpr::getZExtOrBitCast(C, DestTy));
202  }
204  if (C->getType() == DestTy)
205  return C; // avoid calling Fold
206  return Fold(ConstantExpr::getSExtOrBitCast(C, DestTy));
207  }
209  if (C->getType() == DestTy)
210  return C; // avoid calling Fold
211  return Fold(ConstantExpr::getTruncOrBitCast(C, DestTy));
212  }
213 
214  //===--------------------------------------------------------------------===//
215  // Compare Instructions
216  //===--------------------------------------------------------------------===//
217 
219  Constant *RHS) const {
220  return Fold(ConstantExpr::getCompare(P, LHS, RHS));
221  }
223  Constant *RHS) const {
224  return Fold(ConstantExpr::getCompare(P, LHS, RHS));
225  }
226 
227  //===--------------------------------------------------------------------===//
228  // Other Instructions
229  //===--------------------------------------------------------------------===//
230 
231  Constant *CreateSelect(Constant *C, Constant *True, Constant *False) const {
232  return Fold(ConstantExpr::getSelect(C, True, False));
233  }
234 
236  return Fold(ConstantExpr::getExtractElement(Vec, Idx));
237  }
238 
240  Constant *Idx) const {
241  return Fold(ConstantExpr::getInsertElement(Vec, NewElt, Idx));
242  }
243 
245  Constant *Mask) const {
246  return Fold(ConstantExpr::getShuffleVector(V1, V2, Mask));
247  }
248 
250  ArrayRef<unsigned> IdxList) const {
251  return Fold(ConstantExpr::getExtractValue(Agg, IdxList));
252  }
253 
255  ArrayRef<unsigned> IdxList) const {
256  return Fold(ConstantExpr::getInsertValue(Agg, Val, IdxList));
257  }
258 };
259 
260 }
261 
262 #endif
Constant * CreateCast(Instruction::CastOps Op, Constant *C, Type *DestTy) const
Definition: TargetFolder.h:167
static Constant * getFAdd(Constant *C1, Constant *C2)
Definition: Constants.cpp:2036
static Constant * getShuffleVector(Constant *V1, Constant *V2, Constant *Mask)
Definition: Constants.cpp:1949
Constant * CreateShuffleVector(Constant *V1, Constant *V2, Constant *Mask) const
Definition: TargetFolder.h:244
Constant * CreateICmp(CmpInst::Predicate P, Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:218
static Constant * getSelect(Constant *C, Constant *V1, Constant *V2)
Definition: Constants.cpp:1820
Constant * CreateUDiv(Constant *LHS, Constant *RHS, bool isExact=false) const
Definition: TargetFolder.h:71
Constant * CreateMul(Constant *LHS, Constant *RHS, bool HasNUW=false, bool HasNSW=false) const
Definition: TargetFolder.h:64
static Constant * getGetElementPtr(Constant *C, ArrayRef< Constant * > IdxList, bool InBounds=false)
Definition: Constants.h:1004
Constant * CreateSelect(Constant *C, Constant *True, Constant *False) const
Definition: TargetFolder.h:231
static Constant * getExtractElement(Constant *Vec, Constant *Idx)
Definition: Constants.cpp:1912
Constant * CreateFRem(Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:86
Constant * CreateBinOp(Instruction::BinaryOps Opc, Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:109
static Constant * getSub(Constant *C1, Constant *C2, bool HasNUW=false, bool HasNSW=false)
Definition: Constants.cpp:2040
Constant * CreateIntToPtr(Constant *C, Type *DestTy) const
Definition: TargetFolder.h:192
Constant * CreateFCmp(CmpInst::Predicate P, Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:222
Constant * CreateTruncOrBitCast(Constant *C, Type *DestTy) const
Definition: TargetFolder.h:208
static Constant * getAdd(Constant *C1, Constant *C2, bool HasNUW=false, bool HasNSW=false)
Definition: Constants.cpp:2029
static Constant * getFMul(Constant *C1, Constant *C2)
Definition: Constants.cpp:2058
Constant * CreateSRem(Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:83
static Constant * getIntegerCast(Constant *C, Type *Ty, bool isSigned)
Create a ZExt, Bitcast or Trunc for integer -> integer casts.
Definition: Constants.cpp:1502
static Constant * get(unsigned Opcode, Constant *C1, Constant *C2, unsigned Flags=0)
Definition: Constants.cpp:1679
static Constant * getLShr(Constant *C1, Constant *C2, bool isExact=false)
Definition: Constants.cpp:2107
Constant * CreateFAdd(Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:54
static Constant * getExtractValue(Constant *Agg, ArrayRef< unsigned > Idxs)
Definition: Constants.cpp:1989
Constant * CreateInBoundsGetElementPtr(Constant *C, ArrayRef< Value * > IdxList) const
Definition: TargetFolder.h:158
Constant * CreateInsertValue(Constant *Agg, Constant *Val, ArrayRef< unsigned > IdxList) const
Definition: TargetFolder.h:254
static Constant * getFPCast(Constant *C, Type *Ty)
Create a FPExt, Bitcast or FPTrunc for fp -> fp casts.
Definition: Constants.cpp:1515
Constant * CreateShl(Constant *LHS, Constant *RHS, bool HasNUW=false, bool HasNSW=false) const
Definition: TargetFolder.h:89
Constant * CreateFNeg(Constant *C) const
Definition: TargetFolder.h:122
static Constant * getAShr(Constant *C1, Constant *C2, bool isExact=false)
Definition: Constants.cpp:2112
Constant * ConstantFoldConstantExpression(const ConstantExpr *CE, const DataLayout *TD=0, const TargetLibraryInfo *TLI=0)
TargetFolder - Create constants with target dependent folding.
Definition: TargetFolder.h:32
Constant * CreateAShr(Constant *LHS, Constant *RHS, bool isExact=false) const
Definition: TargetFolder.h:96
static Constant * getUDiv(Constant *C1, Constant *C2, bool isExact=false)
Definition: Constants.cpp:2062
static Constant * getFDiv(Constant *C1, Constant *C2)
Definition: Constants.cpp:2072
Constant * CreateGetElementPtr(Constant *C, ArrayRef< Value * > IdxList) const
Definition: TargetFolder.h:143
Constant * CreateXor(Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:105
#define P(N)
static Constant * getFNeg(Constant *C)
Definition: Constants.cpp:2017
static Constant * getFRem(Constant *C1, Constant *C2)
Definition: Constants.cpp:2084
Constant * CreateOr(Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:102
LLVM Constant Representation.
Definition: Constant.h:41
Constant * CreateInBoundsGetElementPtr(Constant *C, Constant *Idx) const
Definition: TargetFolder.h:152
static Constant * getAnd(Constant *C1, Constant *C2)
Definition: Constants.cpp:2088
Constant * CreateExtractElement(Constant *Vec, Constant *Idx) const
Definition: TargetFolder.h:235
static Constant * getSExtOrBitCast(Constant *C, Type *Ty)
Definition: Constants.cpp:1475
Constant * CreateBitCast(Constant *C, Type *DestTy) const
Definition: TargetFolder.h:189
Constant * CreatePointerCast(Constant *C, Type *DestTy) const
Definition: TargetFolder.h:179
static Constant * getNot(Constant *C)
Definition: Constants.cpp:2023
Constant * CreateSDiv(Constant *LHS, Constant *RHS, bool isExact=false) const
Definition: TargetFolder.h:74
Constant * CreateFDiv(Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:77
Constant * CreateGetElementPtr(Constant *C, Constant *Idx) const
Definition: TargetFolder.h:137
Constant * CreateFMul(Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:68
Constant * CreateNeg(Constant *C, bool HasNUW=false, bool HasNSW=false) const
Definition: TargetFolder.h:118
static Constant * getPointerCast(Constant *C, Type *Ty)
Create a BitCast or a PtrToInt cast constant expression.
Definition: Constants.cpp:1487
Constant * CreateFPCast(Constant *C, Type *DestTy) const
Definition: TargetFolder.h:184
static Constant * getSDiv(Constant *C1, Constant *C2, bool isExact=false)
Definition: Constants.cpp:2067
Type * getType() const
Definition: Value.h:111
Constant * CreateSExtOrBitCast(Constant *C, Type *DestTy) const
Definition: TargetFolder.h:203
static Constant * getZExtOrBitCast(Constant *C, Type *Ty)
Definition: Constants.cpp:1469
static Constant * getFSub(Constant *C1, Constant *C2)
Definition: Constants.cpp:2047
static Constant * getTruncOrBitCast(Constant *C, Type *Ty)
Definition: Constants.cpp:1481
static Constant * getNeg(Constant *C, bool HasNUW=false, bool HasNSW=false)
Definition: Constants.cpp:2010
Constant * CreateInBoundsGetElementPtr(Constant *C, ArrayRef< Constant * > IdxList) const
Definition: TargetFolder.h:148
Constant * CreateLShr(Constant *LHS, Constant *RHS, bool isExact=false) const
Definition: TargetFolder.h:93
static Constant * getInBoundsGetElementPtr(Constant *C, ArrayRef< Constant * > IdxList)
Definition: Constants.h:1025
Constant * CreateGetElementPtr(Constant *C, ArrayRef< Constant * > IdxList) const
Definition: TargetFolder.h:133
Constant * CreateAnd(Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:99
Constant * CreateNot(Constant *C) const
Definition: TargetFolder.h:125
static Constant * getOr(Constant *C1, Constant *C2)
Definition: Constants.cpp:2092
static Constant * getShl(Constant *C1, Constant *C2, bool HasNUW=false, bool HasNSW=false)
Definition: Constants.cpp:2100
static Constant * getInsertValue(Constant *Agg, Constant *Val, ArrayRef< unsigned > Idxs)
Definition: Constants.cpp:1969
Constant * CreateSub(Constant *LHS, Constant *RHS, bool HasNUW=false, bool HasNSW=false) const
Definition: TargetFolder.h:57
Constant * CreateInsertElement(Constant *Vec, Constant *NewElt, Constant *Idx) const
Definition: TargetFolder.h:239
Constant * CreateZExtOrBitCast(Constant *C, Type *DestTy) const
Definition: TargetFolder.h:198
Constant * CreateAdd(Constant *LHS, Constant *RHS, bool HasNUW=false, bool HasNSW=false) const
Definition: TargetFolder.h:50
static Constant * getSRem(Constant *C1, Constant *C2)
Definition: Constants.cpp:2080
static Constant * getURem(Constant *C1, Constant *C2)
Definition: Constants.cpp:2076
Constant * CreateURem(Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:80
static Constant * getCompare(unsigned short pred, Constant *C1, Constant *C2)
Return an ICmp or FCmp comparison operator constant expression.
Definition: Constants.cpp:1798
TargetFolder(const DataLayout *TheTD)
Definition: TargetFolder.h:44
Constant * CreateExtractValue(Constant *Agg, ArrayRef< unsigned > IdxList) const
Definition: TargetFolder.h:249
static Constant * getMul(Constant *C1, Constant *C2, bool HasNUW=false, bool HasNSW=false)
Definition: Constants.cpp:2051
static Constant * getCast(unsigned ops, Constant *C, Type *Ty)
Definition: Constants.cpp:1444
Constant * CreateIntCast(Constant *C, Type *DestTy, bool isSigned) const
Definition: TargetFolder.h:173
static Constant * getInsertElement(Constant *Vec, Constant *Elt, Constant *Idx)
Definition: Constants.cpp:1930
Constant * CreateFSub(Constant *LHS, Constant *RHS) const
Definition: TargetFolder.h:61
static Constant * getXor(Constant *C1, Constant *C2)
Definition: Constants.cpp:2096
Constant * CreatePtrToInt(Constant *C, Type *DestTy) const
Definition: TargetFolder.h:195