Previously SimplifyInstruction could report that an instruction

simplified to itself (this can only happen in unreachable blocks).
Change it to return null instead.  Hopefully this will fix some
buildbot failures.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@119490 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Duncan Sands 2010-11-17 08:35:29 +00:00
parent ce1b9ad539
commit d261dc650a
3 changed files with 32 additions and 19 deletions

View File

@ -75,8 +75,6 @@ namespace llvm {
/// SimplifyInstruction - See if we can compute a simplified version of this /// SimplifyInstruction - See if we can compute a simplified version of this
/// instruction. If not, this returns null. /// instruction. If not, this returns null.
/// WARNING: If called on unreachable code, an instruction may be reported
/// to simplify to itself.
Value *SimplifyInstruction(Instruction *I, const TargetData *TD = 0, Value *SimplifyInstruction(Instruction *I, const TargetData *TD = 0,
const DominatorTree *DT = 0); const DominatorTree *DT = 0);

View File

@ -756,34 +756,50 @@ Value *llvm::SimplifyCmpInst(unsigned Predicate, Value *LHS, Value *RHS,
/// instruction. If not, this returns null. /// instruction. If not, this returns null.
Value *llvm::SimplifyInstruction(Instruction *I, const TargetData *TD, Value *llvm::SimplifyInstruction(Instruction *I, const TargetData *TD,
const DominatorTree *DT) { const DominatorTree *DT) {
Value *Result;
switch (I->getOpcode()) { switch (I->getOpcode()) {
default: default:
return ConstantFoldInstruction(I, TD); Result = ConstantFoldInstruction(I, TD);
break;
case Instruction::Add: case Instruction::Add:
return SimplifyAddInst(I->getOperand(0), I->getOperand(1), Result = SimplifyAddInst(I->getOperand(0), I->getOperand(1),
cast<BinaryOperator>(I)->hasNoSignedWrap(), cast<BinaryOperator>(I)->hasNoSignedWrap(),
cast<BinaryOperator>(I)->hasNoUnsignedWrap(), cast<BinaryOperator>(I)->hasNoUnsignedWrap(),
TD, DT); TD, DT);
break;
case Instruction::And: case Instruction::And:
return SimplifyAndInst(I->getOperand(0), I->getOperand(1), TD, DT); Result = SimplifyAndInst(I->getOperand(0), I->getOperand(1), TD, DT);
break;
case Instruction::Or: case Instruction::Or:
return SimplifyOrInst(I->getOperand(0), I->getOperand(1), TD, DT); Result = SimplifyOrInst(I->getOperand(0), I->getOperand(1), TD, DT);
break;
case Instruction::ICmp: case Instruction::ICmp:
return SimplifyICmpInst(cast<ICmpInst>(I)->getPredicate(), Result = SimplifyICmpInst(cast<ICmpInst>(I)->getPredicate(),
I->getOperand(0), I->getOperand(1), TD, DT); I->getOperand(0), I->getOperand(1), TD, DT);
break;
case Instruction::FCmp: case Instruction::FCmp:
return SimplifyFCmpInst(cast<FCmpInst>(I)->getPredicate(), Result = SimplifyFCmpInst(cast<FCmpInst>(I)->getPredicate(),
I->getOperand(0), I->getOperand(1), TD, DT); I->getOperand(0), I->getOperand(1), TD, DT);
break;
case Instruction::Select: case Instruction::Select:
return SimplifySelectInst(I->getOperand(0), I->getOperand(1), Result = SimplifySelectInst(I->getOperand(0), I->getOperand(1),
I->getOperand(2), TD, DT); I->getOperand(2), TD, DT);
break;
case Instruction::GetElementPtr: { case Instruction::GetElementPtr: {
SmallVector<Value*, 8> Ops(I->op_begin(), I->op_end()); SmallVector<Value*, 8> Ops(I->op_begin(), I->op_end());
return SimplifyGEPInst(&Ops[0], Ops.size(), TD, DT); Result = SimplifyGEPInst(&Ops[0], Ops.size(), TD, DT);
break;
} }
case Instruction::PHI: case Instruction::PHI:
return SimplifyPHINode(cast<PHINode>(I), DT); Result = SimplifyPHINode(cast<PHINode>(I), DT);
break;
} }
/// If called on unreachable code, the above logic may report that the
/// instruction simplified to itself. Make life easier for users by
/// detecting that case here, returning null if it occurs.
return Result == I ? 0 : Result;
} }
/// ReplaceAndSimplifyAllUses - Perform From->replaceAllUsesWith(To) and then /// ReplaceAndSimplifyAllUses - Perform From->replaceAllUsesWith(To) and then

View File

@ -616,8 +616,7 @@ Value *Lint::findValueImpl(Value *V, bool OffsetOk,
// As a last resort, try SimplifyInstruction or constant folding. // As a last resort, try SimplifyInstruction or constant folding.
if (Instruction *Inst = dyn_cast<Instruction>(V)) { if (Instruction *Inst = dyn_cast<Instruction>(V)) {
if (Value *W = SimplifyInstruction(Inst, TD, DT)) if (Value *W = SimplifyInstruction(Inst, TD, DT))
if (W != Inst) return findValueImpl(W, OffsetOk, Visited);
return findValueImpl(W, OffsetOk, Visited);
} else if (ConstantExpr *CE = dyn_cast<ConstantExpr>(V)) { } else if (ConstantExpr *CE = dyn_cast<ConstantExpr>(V)) {
if (Value *W = ConstantFoldConstantExpression(CE, TD)) if (Value *W = ConstantFoldConstantExpression(CE, TD))
if (W != V) if (W != V)