1 //===- Evaluator.cpp - LLVM IR evaluator ----------------------------------===//
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
7 //===----------------------------------------------------------------------===//
9 // Function evaluator for LLVM IR.
11 //===----------------------------------------------------------------------===//
13 #include "llvm/Transforms/Utils/Evaluator.h"
14 #include "llvm/ADT/DenseMap.h"
15 #include "llvm/ADT/STLExtras.h"
16 #include "llvm/ADT/SmallPtrSet.h"
17 #include "llvm/ADT/SmallVector.h"
18 #include "llvm/Analysis/ConstantFolding.h"
19 #include "llvm/IR/BasicBlock.h"
20 #include "llvm/IR/Constant.h"
21 #include "llvm/IR/Constants.h"
22 #include "llvm/IR/DataLayout.h"
23 #include "llvm/IR/DerivedTypes.h"
24 #include "llvm/IR/Function.h"
25 #include "llvm/IR/GlobalAlias.h"
26 #include "llvm/IR/GlobalValue.h"
27 #include "llvm/IR/GlobalVariable.h"
28 #include "llvm/IR/InstrTypes.h"
29 #include "llvm/IR/Instruction.h"
30 #include "llvm/IR/Instructions.h"
31 #include "llvm/IR/IntrinsicInst.h"
32 #include "llvm/IR/Intrinsics.h"
33 #include "llvm/IR/Operator.h"
34 #include "llvm/IR/Type.h"
35 #include "llvm/IR/User.h"
36 #include "llvm/IR/Value.h"
37 #include "llvm/Support/Casting.h"
38 #include "llvm/Support/Debug.h"
39 #include "llvm/Support/raw_ostream.h"
42 #define DEBUG_TYPE "evaluator"
47 isSimpleEnoughValueToCommit(Constant
*C
,
48 SmallPtrSetImpl
<Constant
*> &SimpleConstants
,
49 const DataLayout
&DL
);
51 /// Return true if the specified constant can be handled by the code generator.
52 /// We don't want to generate something like:
54 /// because the code generator doesn't have a relocation that can handle that.
56 /// This function should be called if C was not found (but just got inserted)
57 /// in SimpleConstants to avoid having to rescan the same constants all the
60 isSimpleEnoughValueToCommitHelper(Constant
*C
,
61 SmallPtrSetImpl
<Constant
*> &SimpleConstants
,
62 const DataLayout
&DL
) {
63 // Simple global addresses are supported, do not allow dllimport or
64 // thread-local globals.
65 if (auto *GV
= dyn_cast
<GlobalValue
>(C
))
66 return !GV
->hasDLLImportStorageClass() && !GV
->isThreadLocal();
68 // Simple integer, undef, constant aggregate zero, etc are all supported.
69 if (C
->getNumOperands() == 0 || isa
<BlockAddress
>(C
))
72 // Aggregate values are safe if all their elements are.
73 if (isa
<ConstantAggregate
>(C
)) {
74 for (Value
*Op
: C
->operands())
75 if (!isSimpleEnoughValueToCommit(cast
<Constant
>(Op
), SimpleConstants
, DL
))
80 // We don't know exactly what relocations are allowed in constant expressions,
81 // so we allow &global+constantoffset, which is safe and uniformly supported
83 ConstantExpr
*CE
= cast
<ConstantExpr
>(C
);
84 switch (CE
->getOpcode()) {
85 case Instruction::BitCast
:
86 // Bitcast is fine if the casted value is fine.
87 return isSimpleEnoughValueToCommit(CE
->getOperand(0), SimpleConstants
, DL
);
89 case Instruction::IntToPtr
:
90 case Instruction::PtrToInt
:
91 // int <=> ptr is fine if the int type is the same size as the
93 if (DL
.getTypeSizeInBits(CE
->getType()) !=
94 DL
.getTypeSizeInBits(CE
->getOperand(0)->getType()))
96 return isSimpleEnoughValueToCommit(CE
->getOperand(0), SimpleConstants
, DL
);
98 // GEP is fine if it is simple + constant offset.
99 case Instruction::GetElementPtr
:
100 for (unsigned i
= 1, e
= CE
->getNumOperands(); i
!= e
; ++i
)
101 if (!isa
<ConstantInt
>(CE
->getOperand(i
)))
103 return isSimpleEnoughValueToCommit(CE
->getOperand(0), SimpleConstants
, DL
);
105 case Instruction::Add
:
106 // We allow simple+cst.
107 if (!isa
<ConstantInt
>(CE
->getOperand(1)))
109 return isSimpleEnoughValueToCommit(CE
->getOperand(0), SimpleConstants
, DL
);
115 isSimpleEnoughValueToCommit(Constant
*C
,
116 SmallPtrSetImpl
<Constant
*> &SimpleConstants
,
117 const DataLayout
&DL
) {
118 // If we already checked this constant, we win.
119 if (!SimpleConstants
.insert(C
).second
)
121 // Check the constant.
122 return isSimpleEnoughValueToCommitHelper(C
, SimpleConstants
, DL
);
125 /// Return true if this constant is simple enough for us to understand. In
126 /// particular, if it is a cast to anything other than from one pointer type to
127 /// another pointer type, we punt. We basically just support direct accesses to
128 /// globals and GEP's of globals. This should be kept up to date with
130 static bool isSimpleEnoughPointerToCommit(Constant
*C
, const DataLayout
&DL
) {
131 // Conservatively, avoid aggregate types. This is because we don't
132 // want to worry about them partially overlapping other stores.
133 if (!cast
<PointerType
>(C
->getType())->getElementType()->isSingleValueType())
136 if (GlobalVariable
*GV
= dyn_cast
<GlobalVariable
>(C
))
137 // Do not allow weak/*_odr/linkonce linkage or external globals.
138 return GV
->hasUniqueInitializer();
140 if (ConstantExpr
*CE
= dyn_cast
<ConstantExpr
>(C
)) {
141 // Handle a constantexpr gep.
142 if (CE
->getOpcode() == Instruction::GetElementPtr
&&
143 isa
<GlobalVariable
>(CE
->getOperand(0)) &&
144 cast
<GEPOperator
>(CE
)->isInBounds()) {
145 GlobalVariable
*GV
= cast
<GlobalVariable
>(CE
->getOperand(0));
146 // Do not allow weak/*_odr/linkonce/dllimport/dllexport linkage or
148 if (!GV
->hasUniqueInitializer())
151 // The first index must be zero.
152 ConstantInt
*CI
= dyn_cast
<ConstantInt
>(*std::next(CE
->op_begin()));
153 if (!CI
|| !CI
->isZero()) return false;
155 // The remaining indices must be compile-time known integers within the
156 // notional bounds of the corresponding static array types.
157 if (!CE
->isGEPWithNoNotionalOverIndexing())
160 return ConstantFoldLoadThroughGEPConstantExpr(
161 GV
->getInitializer(), CE
,
162 cast
<GEPOperator
>(CE
)->getResultElementType(), DL
);
163 } else if (CE
->getOpcode() == Instruction::BitCast
&&
164 isa
<GlobalVariable
>(CE
->getOperand(0))) {
165 // A constantexpr bitcast from a pointer to another pointer is a no-op,
166 // and we know how to evaluate it by moving the bitcast from the pointer
167 // operand to the value operand.
168 // Do not allow weak/*_odr/linkonce/dllimport/dllexport linkage or
170 return cast
<GlobalVariable
>(CE
->getOperand(0))->hasUniqueInitializer();
177 /// Apply \p TryLoad to Ptr. If this returns \p nullptr, introspect the
178 /// pointer's type and walk down through the initial elements to obtain
179 /// additional pointers to try. Returns the first non-null return value from
180 /// \p TryLoad, or \p nullptr if the type can't be introspected further.
182 evaluateBitcastFromPtr(Constant
*Ptr
, const DataLayout
&DL
,
183 const TargetLibraryInfo
*TLI
,
184 std::function
<Constant
*(Constant
*)> TryLoad
) {
186 while (!(Val
= TryLoad(Ptr
))) {
187 // If Ty is a non-opaque struct, we can convert the pointer to the struct
188 // into a pointer to its first member.
189 // FIXME: This could be extended to support arrays as well.
190 Type
*Ty
= cast
<PointerType
>(Ptr
->getType())->getElementType();
191 if (!isa
<StructType
>(Ty
) || cast
<StructType
>(Ty
)->isOpaque())
194 IntegerType
*IdxTy
= IntegerType::get(Ty
->getContext(), 32);
195 Constant
*IdxZero
= ConstantInt::get(IdxTy
, 0, false);
196 Constant
*const IdxList
[] = {IdxZero
, IdxZero
};
198 Ptr
= ConstantExpr::getGetElementPtr(Ty
, Ptr
, IdxList
);
199 Ptr
= ConstantFoldConstant(Ptr
, DL
, TLI
);
204 static Constant
*getInitializer(Constant
*C
) {
205 auto *GV
= dyn_cast
<GlobalVariable
>(C
);
206 return GV
&& GV
->hasDefinitiveInitializer() ? GV
->getInitializer() : nullptr;
209 /// Return the value that would be computed by a load from P after the stores
210 /// reflected by 'memory' have been performed. If we can't decide, return null.
211 Constant
*Evaluator::ComputeLoadResult(Constant
*P
, Type
*Ty
) {
212 // If this memory location has been recently stored, use the stored value: it
213 // is the most up-to-date.
214 auto TryFindMemLoc
= [this](Constant
*Ptr
) {
215 return MutatedMemory
.lookup(Ptr
);
218 if (Constant
*Val
= TryFindMemLoc(P
))
222 if (GlobalVariable
*GV
= dyn_cast
<GlobalVariable
>(P
)) {
223 if (GV
->hasDefinitiveInitializer())
224 return GV
->getInitializer();
228 if (ConstantExpr
*CE
= dyn_cast
<ConstantExpr
>(P
)) {
229 switch (CE
->getOpcode()) {
230 // Handle a constantexpr getelementptr.
231 case Instruction::GetElementPtr
:
232 if (auto *I
= getInitializer(CE
->getOperand(0)))
233 return ConstantFoldLoadThroughGEPConstantExpr(I
, CE
, Ty
, DL
);
235 // Handle a constantexpr bitcast.
236 case Instruction::BitCast
:
237 // We're evaluating a load through a pointer that was bitcast to a
238 // different type. See if the "from" pointer has recently been stored.
239 // If it hasn't, we may still be able to find a stored pointer by
240 // introspecting the type.
242 evaluateBitcastFromPtr(CE
->getOperand(0), DL
, TLI
, TryFindMemLoc
);
244 Val
= getInitializer(CE
->getOperand(0));
246 return ConstantFoldLoadThroughBitcast(
247 Val
, P
->getType()->getPointerElementType(), DL
);
252 return nullptr; // don't know how to evaluate.
255 static Function
*getFunction(Constant
*C
) {
256 if (auto *Fn
= dyn_cast
<Function
>(C
))
259 if (auto *Alias
= dyn_cast
<GlobalAlias
>(C
))
260 if (auto *Fn
= dyn_cast
<Function
>(Alias
->getAliasee()))
266 Evaluator::getCalleeWithFormalArgs(CallBase
&CB
,
267 SmallVectorImpl
<Constant
*> &Formals
) {
268 auto *V
= CB
.getCalledOperand();
269 if (auto *Fn
= getFunction(getVal(V
)))
270 return getFormalParams(CB
, Fn
, Formals
) ? Fn
: nullptr;
272 auto *CE
= dyn_cast
<ConstantExpr
>(V
);
273 if (!CE
|| CE
->getOpcode() != Instruction::BitCast
||
274 !getFormalParams(CB
, getFunction(CE
->getOperand(0)), Formals
))
277 return dyn_cast
<Function
>(
278 ConstantFoldLoadThroughBitcast(CE
, CE
->getOperand(0)->getType(), DL
));
281 bool Evaluator::getFormalParams(CallBase
&CB
, Function
*F
,
282 SmallVectorImpl
<Constant
*> &Formals
) {
286 auto *FTy
= F
->getFunctionType();
287 if (FTy
->getNumParams() > CB
.getNumArgOperands()) {
288 LLVM_DEBUG(dbgs() << "Too few arguments for function.\n");
292 auto ArgI
= CB
.arg_begin();
293 for (auto ParI
= FTy
->param_begin(), ParE
= FTy
->param_end(); ParI
!= ParE
;
295 auto *ArgC
= ConstantFoldLoadThroughBitcast(getVal(*ArgI
), *ParI
, DL
);
297 LLVM_DEBUG(dbgs() << "Can not convert function argument.\n");
300 Formals
.push_back(ArgC
);
306 /// If call expression contains bitcast then we may need to cast
307 /// evaluated return value to a type of the call expression.
308 Constant
*Evaluator::castCallResultIfNeeded(Value
*CallExpr
, Constant
*RV
) {
309 ConstantExpr
*CE
= dyn_cast
<ConstantExpr
>(CallExpr
);
310 if (!RV
|| !CE
|| CE
->getOpcode() != Instruction::BitCast
)
314 dyn_cast
<FunctionType
>(CE
->getType()->getPointerElementType())) {
315 RV
= ConstantFoldLoadThroughBitcast(RV
, FT
->getReturnType(), DL
);
317 LLVM_DEBUG(dbgs() << "Failed to fold bitcast call expr\n");
322 /// Evaluate all instructions in block BB, returning true if successful, false
323 /// if we can't evaluate it. NewBB returns the next BB that control flows into,
324 /// or null upon return. StrippedPointerCastsForAliasAnalysis is set to true if
325 /// we looked through pointer casts to evaluate something.
326 bool Evaluator::EvaluateBlock(BasicBlock::iterator CurInst
, BasicBlock
*&NextBB
,
327 bool &StrippedPointerCastsForAliasAnalysis
) {
328 // This is the main evaluation loop.
330 Constant
*InstResult
= nullptr;
332 LLVM_DEBUG(dbgs() << "Evaluating Instruction: " << *CurInst
<< "\n");
334 if (StoreInst
*SI
= dyn_cast
<StoreInst
>(CurInst
)) {
335 if (!SI
->isSimple()) {
336 LLVM_DEBUG(dbgs() << "Store is not simple! Can not evaluate.\n");
337 return false; // no volatile/atomic accesses.
339 Constant
*Ptr
= getVal(SI
->getOperand(1));
340 Constant
*FoldedPtr
= ConstantFoldConstant(Ptr
, DL
, TLI
);
341 if (Ptr
!= FoldedPtr
) {
342 LLVM_DEBUG(dbgs() << "Folding constant ptr expression: " << *Ptr
);
344 LLVM_DEBUG(dbgs() << "; To: " << *Ptr
<< "\n");
346 if (!isSimpleEnoughPointerToCommit(Ptr
, DL
)) {
347 // If this is too complex for us to commit, reject it.
349 dbgs() << "Pointer is too complex for us to evaluate store.");
353 Constant
*Val
= getVal(SI
->getOperand(0));
355 // If this might be too difficult for the backend to handle (e.g. the addr
356 // of one global variable divided by another) then we can't commit it.
357 if (!isSimpleEnoughValueToCommit(Val
, SimpleConstants
, DL
)) {
358 LLVM_DEBUG(dbgs() << "Store value is too complex to evaluate store. "
363 if (ConstantExpr
*CE
= dyn_cast
<ConstantExpr
>(Ptr
)) {
364 if (CE
->getOpcode() == Instruction::BitCast
) {
366 << "Attempting to resolve bitcast on constant ptr.\n");
367 // If we're evaluating a store through a bitcast, then we need
368 // to pull the bitcast off the pointer type and push it onto the
369 // stored value. In order to push the bitcast onto the stored value,
370 // a bitcast from the pointer's element type to Val's type must be
371 // legal. If it's not, we can try introspecting the type to find a
374 auto TryCastValTy
= [&](Constant
*P
) -> Constant
* {
375 // The conversion is illegal if the store is wider than the
376 // pointee proposed by `evaluateBitcastFromPtr`, since that would
377 // drop stores to other struct elements when the caller attempts to
378 // look through a struct's 0th element.
379 Type
*NewTy
= cast
<PointerType
>(P
->getType())->getElementType();
380 Type
*STy
= Val
->getType();
381 if (DL
.getTypeSizeInBits(NewTy
) < DL
.getTypeSizeInBits(STy
))
384 if (Constant
*FV
= ConstantFoldLoadThroughBitcast(Val
, NewTy
, DL
)) {
392 evaluateBitcastFromPtr(CE
->getOperand(0), DL
, TLI
, TryCastValTy
);
394 LLVM_DEBUG(dbgs() << "Failed to bitcast constant ptr, can not "
400 LLVM_DEBUG(dbgs() << "Evaluated bitcast: " << *Val
<< "\n");
404 MutatedMemory
[Ptr
] = Val
;
405 } else if (BinaryOperator
*BO
= dyn_cast
<BinaryOperator
>(CurInst
)) {
406 InstResult
= ConstantExpr::get(BO
->getOpcode(),
407 getVal(BO
->getOperand(0)),
408 getVal(BO
->getOperand(1)));
409 LLVM_DEBUG(dbgs() << "Found a BinaryOperator! Simplifying: "
410 << *InstResult
<< "\n");
411 } else if (CmpInst
*CI
= dyn_cast
<CmpInst
>(CurInst
)) {
412 InstResult
= ConstantExpr::getCompare(CI
->getPredicate(),
413 getVal(CI
->getOperand(0)),
414 getVal(CI
->getOperand(1)));
415 LLVM_DEBUG(dbgs() << "Found a CmpInst! Simplifying: " << *InstResult
417 } else if (CastInst
*CI
= dyn_cast
<CastInst
>(CurInst
)) {
418 InstResult
= ConstantExpr::getCast(CI
->getOpcode(),
419 getVal(CI
->getOperand(0)),
421 LLVM_DEBUG(dbgs() << "Found a Cast! Simplifying: " << *InstResult
423 } else if (SelectInst
*SI
= dyn_cast
<SelectInst
>(CurInst
)) {
424 InstResult
= ConstantExpr::getSelect(getVal(SI
->getOperand(0)),
425 getVal(SI
->getOperand(1)),
426 getVal(SI
->getOperand(2)));
427 LLVM_DEBUG(dbgs() << "Found a Select! Simplifying: " << *InstResult
429 } else if (auto *EVI
= dyn_cast
<ExtractValueInst
>(CurInst
)) {
430 InstResult
= ConstantExpr::getExtractValue(
431 getVal(EVI
->getAggregateOperand()), EVI
->getIndices());
432 LLVM_DEBUG(dbgs() << "Found an ExtractValueInst! Simplifying: "
433 << *InstResult
<< "\n");
434 } else if (auto *IVI
= dyn_cast
<InsertValueInst
>(CurInst
)) {
435 InstResult
= ConstantExpr::getInsertValue(
436 getVal(IVI
->getAggregateOperand()),
437 getVal(IVI
->getInsertedValueOperand()), IVI
->getIndices());
438 LLVM_DEBUG(dbgs() << "Found an InsertValueInst! Simplifying: "
439 << *InstResult
<< "\n");
440 } else if (GetElementPtrInst
*GEP
= dyn_cast
<GetElementPtrInst
>(CurInst
)) {
441 Constant
*P
= getVal(GEP
->getOperand(0));
442 SmallVector
<Constant
*, 8> GEPOps
;
443 for (Use
&Op
: llvm::drop_begin(GEP
->operands()))
444 GEPOps
.push_back(getVal(Op
));
446 ConstantExpr::getGetElementPtr(GEP
->getSourceElementType(), P
, GEPOps
,
447 cast
<GEPOperator
>(GEP
)->isInBounds());
448 LLVM_DEBUG(dbgs() << "Found a GEP! Simplifying: " << *InstResult
<< "\n");
449 } else if (LoadInst
*LI
= dyn_cast
<LoadInst
>(CurInst
)) {
450 if (!LI
->isSimple()) {
452 dbgs() << "Found a Load! Not a simple load, can not evaluate.\n");
453 return false; // no volatile/atomic accesses.
456 Constant
*Ptr
= getVal(LI
->getOperand(0));
457 Constant
*FoldedPtr
= ConstantFoldConstant(Ptr
, DL
, TLI
);
458 if (Ptr
!= FoldedPtr
) {
460 LLVM_DEBUG(dbgs() << "Found a constant pointer expression, constant "
464 InstResult
= ComputeLoadResult(Ptr
, LI
->getType());
467 dbgs() << "Failed to compute load result. Can not evaluate load."
469 return false; // Could not evaluate load.
472 LLVM_DEBUG(dbgs() << "Evaluated load: " << *InstResult
<< "\n");
473 } else if (AllocaInst
*AI
= dyn_cast
<AllocaInst
>(CurInst
)) {
474 if (AI
->isArrayAllocation()) {
475 LLVM_DEBUG(dbgs() << "Found an array alloca. Can not evaluate.\n");
476 return false; // Cannot handle array allocs.
478 Type
*Ty
= AI
->getAllocatedType();
479 AllocaTmps
.push_back(std::make_unique
<GlobalVariable
>(
480 Ty
, false, GlobalValue::InternalLinkage
, UndefValue::get(Ty
),
481 AI
->getName(), /*TLMode=*/GlobalValue::NotThreadLocal
,
482 AI
->getType()->getPointerAddressSpace()));
483 InstResult
= AllocaTmps
.back().get();
484 LLVM_DEBUG(dbgs() << "Found an alloca. Result: " << *InstResult
<< "\n");
485 } else if (isa
<CallInst
>(CurInst
) || isa
<InvokeInst
>(CurInst
)) {
486 CallBase
&CB
= *cast
<CallBase
>(&*CurInst
);
488 // Debug info can safely be ignored here.
489 if (isa
<DbgInfoIntrinsic
>(CB
)) {
490 LLVM_DEBUG(dbgs() << "Ignoring debug info.\n");
495 // Cannot handle inline asm.
496 if (CB
.isInlineAsm()) {
497 LLVM_DEBUG(dbgs() << "Found inline asm, can not evaluate.\n");
501 if (IntrinsicInst
*II
= dyn_cast
<IntrinsicInst
>(&CB
)) {
502 if (MemSetInst
*MSI
= dyn_cast
<MemSetInst
>(II
)) {
503 if (MSI
->isVolatile()) {
504 LLVM_DEBUG(dbgs() << "Can not optimize a volatile memset "
508 Constant
*Ptr
= getVal(MSI
->getDest());
509 Constant
*Val
= getVal(MSI
->getValue());
511 ComputeLoadResult(getVal(Ptr
), MSI
->getValue()->getType());
512 if (Val
->isNullValue() && DestVal
&& DestVal
->isNullValue()) {
513 // This memset is a no-op.
514 LLVM_DEBUG(dbgs() << "Ignoring no-op memset.\n");
520 if (II
->isLifetimeStartOrEnd()) {
521 LLVM_DEBUG(dbgs() << "Ignoring lifetime intrinsic.\n");
526 if (II
->getIntrinsicID() == Intrinsic::invariant_start
) {
527 // We don't insert an entry into Values, as it doesn't have a
528 // meaningful return value.
529 if (!II
->use_empty()) {
531 << "Found unused invariant_start. Can't evaluate.\n");
534 ConstantInt
*Size
= cast
<ConstantInt
>(II
->getArgOperand(0));
535 Value
*PtrArg
= getVal(II
->getArgOperand(1));
536 Value
*Ptr
= PtrArg
->stripPointerCasts();
537 if (GlobalVariable
*GV
= dyn_cast
<GlobalVariable
>(Ptr
)) {
538 Type
*ElemTy
= GV
->getValueType();
539 if (!Size
->isMinusOne() &&
540 Size
->getValue().getLimitedValue() >=
541 DL
.getTypeStoreSize(ElemTy
)) {
542 Invariants
.insert(GV
);
543 LLVM_DEBUG(dbgs() << "Found a global var that is an invariant: "
547 << "Found a global var, but can not treat it as an "
551 // Continue even if we do nothing.
554 } else if (II
->getIntrinsicID() == Intrinsic::assume
) {
555 LLVM_DEBUG(dbgs() << "Skipping assume intrinsic.\n");
558 } else if (II
->getIntrinsicID() == Intrinsic::sideeffect
) {
559 LLVM_DEBUG(dbgs() << "Skipping sideeffect intrinsic.\n");
562 } else if (II
->getIntrinsicID() == Intrinsic::pseudoprobe
) {
563 LLVM_DEBUG(dbgs() << "Skipping pseudoprobe intrinsic.\n");
567 Value
*Stripped
= CurInst
->stripPointerCastsForAliasAnalysis();
568 // Only attempt to getVal() if we've actually managed to strip
569 // anything away, or else we'll call getVal() on the current
571 if (Stripped
!= &*CurInst
) {
572 InstResult
= getVal(Stripped
);
576 << "Stripped pointer casts for alias analysis for "
577 "intrinsic call.\n");
578 StrippedPointerCastsForAliasAnalysis
= true;
579 InstResult
= ConstantExpr::getBitCast(InstResult
, II
->getType());
581 LLVM_DEBUG(dbgs() << "Unknown intrinsic. Cannot evaluate.\n");
588 // Resolve function pointers.
589 SmallVector
<Constant
*, 8> Formals
;
590 Function
*Callee
= getCalleeWithFormalArgs(CB
, Formals
);
591 if (!Callee
|| Callee
->isInterposable()) {
592 LLVM_DEBUG(dbgs() << "Can not resolve function pointer.\n");
593 return false; // Cannot resolve.
596 if (Callee
->isDeclaration()) {
597 // If this is a function we can constant fold, do it.
598 if (Constant
*C
= ConstantFoldCall(&CB
, Callee
, Formals
, TLI
)) {
599 InstResult
= castCallResultIfNeeded(CB
.getCalledOperand(), C
);
602 LLVM_DEBUG(dbgs() << "Constant folded function call. Result: "
603 << *InstResult
<< "\n");
605 LLVM_DEBUG(dbgs() << "Can not constant fold function call.\n");
609 if (Callee
->getFunctionType()->isVarArg()) {
611 << "Can not constant fold vararg function call.\n");
615 Constant
*RetVal
= nullptr;
616 // Execute the call, if successful, use the return value.
617 ValueStack
.emplace_back();
618 if (!EvaluateFunction(Callee
, RetVal
, Formals
)) {
619 LLVM_DEBUG(dbgs() << "Failed to evaluate function.\n");
622 ValueStack
.pop_back();
623 InstResult
= castCallResultIfNeeded(CB
.getCalledOperand(), RetVal
);
624 if (RetVal
&& !InstResult
)
628 LLVM_DEBUG(dbgs() << "Successfully evaluated function. Result: "
629 << *InstResult
<< "\n\n");
632 << "Successfully evaluated function. Result: 0\n\n");
636 } else if (CurInst
->isTerminator()) {
637 LLVM_DEBUG(dbgs() << "Found a terminator instruction.\n");
639 if (BranchInst
*BI
= dyn_cast
<BranchInst
>(CurInst
)) {
640 if (BI
->isUnconditional()) {
641 NextBB
= BI
->getSuccessor(0);
644 dyn_cast
<ConstantInt
>(getVal(BI
->getCondition()));
645 if (!Cond
) return false; // Cannot determine.
647 NextBB
= BI
->getSuccessor(!Cond
->getZExtValue());
649 } else if (SwitchInst
*SI
= dyn_cast
<SwitchInst
>(CurInst
)) {
651 dyn_cast
<ConstantInt
>(getVal(SI
->getCondition()));
652 if (!Val
) return false; // Cannot determine.
653 NextBB
= SI
->findCaseValue(Val
)->getCaseSuccessor();
654 } else if (IndirectBrInst
*IBI
= dyn_cast
<IndirectBrInst
>(CurInst
)) {
655 Value
*Val
= getVal(IBI
->getAddress())->stripPointerCasts();
656 if (BlockAddress
*BA
= dyn_cast
<BlockAddress
>(Val
))
657 NextBB
= BA
->getBasicBlock();
659 return false; // Cannot determine.
660 } else if (isa
<ReturnInst
>(CurInst
)) {
663 // invoke, unwind, resume, unreachable.
664 LLVM_DEBUG(dbgs() << "Can not handle terminator.");
665 return false; // Cannot handle this terminator.
668 // We succeeded at evaluating this block!
669 LLVM_DEBUG(dbgs() << "Successfully evaluated block.\n");
672 // Did not know how to evaluate this!
674 dbgs() << "Failed to evaluate block due to unhandled instruction."
679 if (!CurInst
->use_empty()) {
680 InstResult
= ConstantFoldConstant(InstResult
, DL
, TLI
);
681 setVal(&*CurInst
, InstResult
);
684 // If we just processed an invoke, we finished evaluating the block.
685 if (InvokeInst
*II
= dyn_cast
<InvokeInst
>(CurInst
)) {
686 NextBB
= II
->getNormalDest();
687 LLVM_DEBUG(dbgs() << "Found an invoke instruction. Finished Block.\n\n");
691 // Advance program counter.
696 /// Evaluate a call to function F, returning true if successful, false if we
697 /// can't evaluate it. ActualArgs contains the formal arguments for the
699 bool Evaluator::EvaluateFunction(Function
*F
, Constant
*&RetVal
,
700 const SmallVectorImpl
<Constant
*> &ActualArgs
) {
701 // Check to see if this function is already executing (recursion). If so,
702 // bail out. TODO: we might want to accept limited recursion.
703 if (is_contained(CallStack
, F
))
706 CallStack
.push_back(F
);
708 // Initialize arguments to the incoming values specified.
710 for (Function::arg_iterator AI
= F
->arg_begin(), E
= F
->arg_end(); AI
!= E
;
712 setVal(&*AI
, ActualArgs
[ArgNo
]);
714 // ExecutedBlocks - We only handle non-looping, non-recursive code. As such,
715 // we can only evaluate any one basic block at most once. This set keeps
716 // track of what we have executed so we can detect recursive cases etc.
717 SmallPtrSet
<BasicBlock
*, 32> ExecutedBlocks
;
719 // CurBB - The current basic block we're evaluating.
720 BasicBlock
*CurBB
= &F
->front();
722 BasicBlock::iterator CurInst
= CurBB
->begin();
725 BasicBlock
*NextBB
= nullptr; // Initialized to avoid compiler warnings.
726 LLVM_DEBUG(dbgs() << "Trying to evaluate BB: " << *CurBB
<< "\n");
728 bool StrippedPointerCastsForAliasAnalysis
= false;
730 if (!EvaluateBlock(CurInst
, NextBB
, StrippedPointerCastsForAliasAnalysis
))
734 // Successfully running until there's no next block means that we found
735 // the return. Fill it the return value and pop the call stack.
736 ReturnInst
*RI
= cast
<ReturnInst
>(CurBB
->getTerminator());
737 if (RI
->getNumOperands()) {
738 // The Evaluator can look through pointer casts as long as alias
739 // analysis holds because it's just a simple interpreter and doesn't
740 // skip memory accesses due to invariant group metadata, but we can't
741 // let users of Evaluator use a value that's been gleaned looking
742 // through stripping pointer casts.
743 if (StrippedPointerCastsForAliasAnalysis
&&
744 !RI
->getReturnValue()->getType()->isVoidTy()) {
747 RetVal
= getVal(RI
->getOperand(0));
749 CallStack
.pop_back();
753 // Okay, we succeeded in evaluating this control flow. See if we have
754 // executed the new block before. If so, we have a looping function,
755 // which we cannot evaluate in reasonable time.
756 if (!ExecutedBlocks
.insert(NextBB
).second
)
757 return false; // looped!
759 // Okay, we have never been in this block before. Check to see if there
760 // are any PHI nodes. If so, evaluate them with information about where
762 PHINode
*PN
= nullptr;
763 for (CurInst
= NextBB
->begin();
764 (PN
= dyn_cast
<PHINode
>(CurInst
)); ++CurInst
)
765 setVal(PN
, getVal(PN
->getIncomingValueForBlock(CurBB
)));
767 // Advance to the next block.