aboutsummaryrefslogtreecommitdiff
path: root/lib/Transforms/IPO/GlobalOpt.cpp
diff options
context:
space:
mode:
authorDan Gohman <gohman@apple.com>2012-03-13 18:01:37 +0000
committerDan Gohman <gohman@apple.com>2012-03-13 18:01:37 +0000
commitf1ce79f3c359bf33c2f30a74625a9babc3cc2a48 (patch)
treeb3fa851c82ff3deeefcc7e2d8be1759a89632c33 /lib/Transforms/IPO/GlobalOpt.cpp
parentbd0fe5642544d4ec3aee1ede7af60c006bae5cbf (diff)
Teach globalopt how to evaluate an invoke with a non-void return type.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@152634 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Transforms/IPO/GlobalOpt.cpp')
-rw-r--r--lib/Transforms/IPO/GlobalOpt.cpp11
1 files changed, 6 insertions, 5 deletions
diff --git a/lib/Transforms/IPO/GlobalOpt.cpp b/lib/Transforms/IPO/GlobalOpt.cpp
index cd0dcbfe72..a32e550954 100644
--- a/lib/Transforms/IPO/GlobalOpt.cpp
+++ b/lib/Transforms/IPO/GlobalOpt.cpp
@@ -2561,11 +2561,6 @@ bool Evaluator::EvaluateBlock(BasicBlock::iterator CurInst,
return false;
delete ValueStack.pop_back_val();
InstResult = RetVal;
-
- if (InvokeInst *II = dyn_cast<InvokeInst>(CurInst)) {
- NextBB = II->getNormalDest();
- return true;
- }
}
} else if (isa<TerminatorInst>(CurInst)) {
if (BranchInst *BI = dyn_cast<BranchInst>(CurInst)) {
@@ -2610,6 +2605,12 @@ bool Evaluator::EvaluateBlock(BasicBlock::iterator CurInst,
setVal(CurInst, InstResult);
}
+ // If we just processed an invoke, we finished evaluating the block.
+ if (InvokeInst *II = dyn_cast<InvokeInst>(CurInst)) {
+ NextBB = II->getNormalDest();
+ return true;
+ }
+
// Advance program counter.
++CurInst;
}