summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorEugene Leviant <eleviant@accesssoftek.com>2018-06-22 08:57:01 +0000
committerEugene Leviant <eleviant@accesssoftek.com>2018-06-22 08:57:01 +0000
commit6d711ca168ac65d003a09076db2599475a8354a4 (patch)
treecbc39b9eff131b723f30fd82f3d6f66524e8cc8d /llvm/lib
parent8d2f1565b77caa47d6f38b7878bada45cdbfe1c5 (diff)
downloadbcm5719-llvm-6d711ca168ac65d003a09076db2599475a8354a4.tar.gz
bcm5719-llvm-6d711ca168ac65d003a09076db2599475a8354a4.zip
Revert r335324 due to a builtbot failure
llvm-svn: 335327
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Transforms/Utils/Evaluator.cpp33
1 files changed, 3 insertions, 30 deletions
diff --git a/llvm/lib/Transforms/Utils/Evaluator.cpp b/llvm/lib/Transforms/Utils/Evaluator.cpp
index 3f9daa2d29a..9440ae3ef2a 100644
--- a/llvm/lib/Transforms/Utils/Evaluator.cpp
+++ b/llvm/lib/Transforms/Utils/Evaluator.cpp
@@ -217,33 +217,6 @@ Constant *Evaluator::ComputeLoadResult(Constant *P) {
return nullptr; // don't know how to evaluate.
}
-Function *Evaluator::getCallee(Value *V) {
- auto *CE = dyn_cast<ConstantExpr>(V);
- if (!CE)
- return dyn_cast<Function>(getVal(V));
-
- Constant *C =
- CE->getOpcode() == Instruction::BitCast
- ? ConstantFoldLoadThroughBitcast(CE, CE->getOperand(0)->getType(), DL)
- : CE;
- return dyn_cast<Function>(C);
-}
-
-/// If call expression contains bitcast then we may need to cast
-/// evaluated return value to a type of the call expression.
-Constant *Evaluator::castCallResultIfNeeded(Value *CallExpr, Constant *RV) {
- ConstantExpr *CE = dyn_cast<ConstantExpr>(CallExpr);
- if (!CE || CE->getOpcode() != Instruction::BitCast)
- return RV;
-
- if (auto *FT =
- dyn_cast<FunctionType>(CE->getType()->getPointerElementType())) {
- RV = ConstantFoldLoadThroughBitcast(RV, FT->getReturnType(), DL);
- assert(RV && "Failed to fold bitcast call expr");
- }
- return RV;
-}
-
/// Evaluate all instructions in block BB, returning true if successful, false
/// if we can't evaluate it. NewBB returns the next BB that control flows into,
/// or null upon return.
@@ -492,7 +465,7 @@ bool Evaluator::EvaluateBlock(BasicBlock::iterator CurInst,
}
// Resolve function pointers.
- Function *Callee = getCallee(CS.getCalledValue());
+ Function *Callee = dyn_cast<Function>(getVal(CS.getCalledValue()));
if (!Callee || Callee->isInterposable()) {
LLVM_DEBUG(dbgs() << "Can not resolve function pointer.\n");
return false; // Cannot resolve.
@@ -505,7 +478,7 @@ bool Evaluator::EvaluateBlock(BasicBlock::iterator CurInst,
if (Callee->isDeclaration()) {
// If this is a function we can constant fold, do it.
if (Constant *C = ConstantFoldCall(CS, Callee, Formals, TLI)) {
- InstResult = castCallResultIfNeeded(CS.getCalledValue(), C);
+ InstResult = C;
LLVM_DEBUG(dbgs() << "Constant folded function call. Result: "
<< *InstResult << "\n");
} else {
@@ -526,7 +499,7 @@ bool Evaluator::EvaluateBlock(BasicBlock::iterator CurInst,
return false;
}
ValueStack.pop_back();
- InstResult = castCallResultIfNeeded(CS.getCalledValue(), RetVal);
+ InstResult = RetVal;
if (InstResult) {
LLVM_DEBUG(dbgs() << "Successfully evaluated function. Result: "
OpenPOWER on IntegriCloud