From: Chris Lattner Date: Mon, 17 Oct 2005 17:56:38 +0000 (+0000) Subject: Oops, X+0.0 isn't foldable, but X+-0.0 is. X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=5e678e03b72487d53117b05d23fd23f29bd8c344;p=oota-llvm.git Oops, X+0.0 isn't foldable, but X+-0.0 is. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23772 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Scalar/InstructionCombining.cpp b/lib/Transforms/Scalar/InstructionCombining.cpp index 67a54018c37..d92e126b080 100644 --- a/lib/Transforms/Scalar/InstructionCombining.cpp +++ b/lib/Transforms/Scalar/InstructionCombining.cpp @@ -694,11 +694,12 @@ Instruction *InstCombiner::visitAdd(BinaryOperator &I) { return ReplaceInstUsesWith(I, RHS); // X + 0 --> X - // NOTE: -0 + +0 = +0 in non-default rounding modes. When we support them - // we must disable this. Note that 0.0-0.0 = -0.0, so this doesn't hold - // for SUB. - if (RHSC->isNullValue()) + if (!I.getType()->isFloatingPoint()) { // NOTE: -0 + +0 = +0. + if (RHSC->isNullValue()) + return ReplaceInstUsesWith(I, LHS); + } else if (cast(RHSC)->isExactlyValue(-0.0)) { return ReplaceInstUsesWith(I, LHS); + } // X + (signbit) --> X ^ signbit if (ConstantInt *CI = dyn_cast(RHSC)) {