From: Chris Lattner Date: Wed, 25 Jun 2003 17:09:20 +0000 (+0000) Subject: Instcombine: X * -1 -> -X X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=0af1fab019fba132f40748fe549cf6b1d5d8672b;p=oota-llvm.git Instcombine: X * -1 -> -X git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@6904 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp index 505313ba9c3..696575e3d6b 100644 --- a/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/lib/Transforms/Scalar/InstructionCombining.cpp @@ -361,10 +361,11 @@ Instruction *InstCombiner::visitMul(BinaryOperator &I) { if (Constant *Op1 = dyn_cast(I.getOperand(1))) { if (ConstantInt *CI = dyn_cast(Op1)) { const Type *Ty = CI->getType(); - uint64_t Val = Ty->isSigned() ? - (uint64_t)cast(CI)->getValue() : - cast(CI)->getValue(); + int64_t Val = Ty->isSigned() ? cast(CI)->getValue() : + (int64_t)cast(CI)->getValue(); switch (Val) { + case -1: // X * -1 -> -X + return BinaryOperator::createNeg(Op0, I.getName()); case 0: return ReplaceInstUsesWith(I, Op1); // Eliminate 'mul double %X, 0' case 1: