aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorOwen Anderson <resistor@mac.com>2010-09-16 20:51:41 +0000
committerOwen Anderson <resistor@mac.com>2010-09-16 20:51:41 +0000
commit4e282decf3960bfa6b1fe3fd77bb51ff96121515 (patch)
treebdffe2a3ec4edaf9b9a90bf77c142d645c66e1b4 /lib
parent35aa94b229d516b9eb775ad4e13a8e2d03221cf9 (diff)
downloadexternal_llvm-4e282decf3960bfa6b1fe3fd77bb51ff96121515.zip
external_llvm-4e282decf3960bfa6b1fe3fd77bb51ff96121515.tar.gz
external_llvm-4e282decf3960bfa6b1fe3fd77bb51ff96121515.tar.bz2
Revert r114097, adding back in the assertion against replacing an Instruction by itself. Now that CorrelatedValuePropagation is
more careful not to call SimplifyInstructionsInBlock() on an unreachable block, the issue has been fixed at a higher level. Add a big warning to SimplifyInstructionsInBlock() to hopefully prevent this in the future. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@114117 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/Analysis/InstructionSimplify.cpp35
1 files changed, 11 insertions, 24 deletions
diff --git a/lib/Analysis/InstructionSimplify.cpp b/lib/Analysis/InstructionSimplify.cpp
index 5bc117d..b49b4d0 100644
--- a/lib/Analysis/InstructionSimplify.cpp
+++ b/lib/Analysis/InstructionSimplify.cpp
@@ -423,44 +423,31 @@ Value *llvm::SimplifyCmpInst(unsigned Predicate, Value *LHS, Value *RHS,
/// SimplifyInstruction - See if we can compute a simplified version of this
/// instruction. If not, this returns null.
Value *llvm::SimplifyInstruction(Instruction *I, const TargetData *TD) {
- Value *Ret = 0;
switch (I->getOpcode()) {
default:
return ConstantFoldInstruction(I, TD);
case Instruction::Add:
- Ret = SimplifyAddInst(I->getOperand(0), I->getOperand(1),
- cast<BinaryOperator>(I)->hasNoSignedWrap(),
- cast<BinaryOperator>(I)->hasNoUnsignedWrap(), TD);
- break;
+ return SimplifyAddInst(I->getOperand(0), I->getOperand(1),
+ cast<BinaryOperator>(I)->hasNoSignedWrap(),
+ cast<BinaryOperator>(I)->hasNoUnsignedWrap(), TD);
case Instruction::And:
- Ret = SimplifyAndInst(I->getOperand(0), I->getOperand(1), TD);
- break;
+ return SimplifyAndInst(I->getOperand(0), I->getOperand(1), TD);
case Instruction::Or:
- Ret = SimplifyOrInst(I->getOperand(0), I->getOperand(1), TD);
- break;
+ return SimplifyOrInst(I->getOperand(0), I->getOperand(1), TD);
case Instruction::ICmp:
- Ret = SimplifyICmpInst(cast<ICmpInst>(I)->getPredicate(),
- I->getOperand(0), I->getOperand(1), TD);
- break;
+ return SimplifyICmpInst(cast<ICmpInst>(I)->getPredicate(),
+ I->getOperand(0), I->getOperand(1), TD);
case Instruction::FCmp:
- Ret = SimplifyFCmpInst(cast<FCmpInst>(I)->getPredicate(),
- I->getOperand(0), I->getOperand(1), TD);
- break;
+ return SimplifyFCmpInst(cast<FCmpInst>(I)->getPredicate(),
+ I->getOperand(0), I->getOperand(1), TD);
case Instruction::Select:
- Ret = SimplifySelectInst(I->getOperand(0), I->getOperand(1),
+ return SimplifySelectInst(I->getOperand(0), I->getOperand(1),
I->getOperand(2), TD);
- break;
case Instruction::GetElementPtr: {
SmallVector<Value*, 8> Ops(I->op_begin(), I->op_end());
- Ret = SimplifyGEPInst(&Ops[0], Ops.size(), TD);
- break;
+ return SimplifyGEPInst(&Ops[0], Ops.size(), TD);
}
}
-
- // It is possible, in situations involving unreachable loops, to
- // have a replacement that, through recursive simplification, ends up
- // simplifying to itself.
- return Ret != I ? Ret : 0;
}
/// ReplaceAndSimplifyAllUses - Perform From->replaceAllUsesWith(To) and then