From: Chris Lattner Date: Tue, 10 Sep 2002 23:04:09 +0000 (+0000) Subject: Add cannonicalization of shl X, 1 -> add X, X X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=f283608f2ea7fd52fdd5d283a1f199b95efb931d;p=oota-llvm.git Add cannonicalization of shl X, 1 -> add X, X git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3671 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp index 785eb709aa4..9c1076e4481 100644 --- a/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/lib/Transforms/Scalar/InstructionCombining.cpp @@ -490,10 +490,18 @@ Instruction *InstCombiner::visitShiftInst(Instruction &I) { // a signed value. // if (ConstantUInt *CUI = dyn_cast(Op1)) { - unsigned TypeBits = Op0->getType()->getPrimitiveSize()*8; - if (CUI->getValue() >= TypeBits && - !(Op0->getType()->isSigned() && I.getOpcode() == Instruction::Shr)) - return ReplaceInstUsesWith(I, Constant::getNullValue(Op0->getType())); + if (I.getOpcode() == Instruction::Shr) { + unsigned TypeBits = Op0->getType()->getPrimitiveSize()*8; + if (CUI->getValue() >= TypeBits && !(Op0->getType()->isSigned())) + return ReplaceInstUsesWith(I, Constant::getNullValue(Op0->getType())); + } + + // Check to see if we are shifting left by 1. If so, turn it into an add + // instruction. + if (I.getOpcode() == Instruction::Shl && CUI->equalsInt(1)) + // Convert 'shl int %X, 2' to 'add int %X, %X' + return BinaryOperator::create(Instruction::Add, Op0, Op0, I.getName()); + } return 0; }