From: Chris Lattner Date: Mon, 6 May 2002 17:03:21 +0000 (+0000) Subject: Combine not (not X) -> X X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=ed3a55005d62165248bfb2f99302892ffde3841c;p=oota-llvm.git Combine not (not X) -> X git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2493 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp index 9679a2b6aab..0c089120ead 100644 --- a/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/lib/Transforms/Scalar/InstructionCombining.cpp @@ -57,7 +57,7 @@ namespace { // I - Change was made, I is still valid // otherwise - Change was made, replace I with returned instruction // - + Instruction *visitNot(UnaryOperator *I); Instruction *visitAdd(BinaryOperator *I); Instruction *visitSub(BinaryOperator *I); Instruction *visitMul(BinaryOperator *I); @@ -78,6 +78,19 @@ namespace { } +Instruction *InstCombiner::visitNot(UnaryOperator *I) { + if (I->use_empty()) return 0; // Don't fix dead instructions... + + // not (not X) = X + if (Instruction *Op = dyn_cast(I->getOperand(0))) + if (Op->getOpcode() == Instruction::Not) { + AddUsesToWorkList(I); // Add all modified instrs to worklist + I->replaceAllUsesWith(Op->getOperand(0)); + return I; + } + return 0; +} + // Make sure that this instruction has a constant on the right hand side if it // has any constant arguments. If not, fix it an return true.