From: Michael Ilseman Date: Thu, 6 Dec 2012 00:07:09 +0000 (+0000) Subject: Have CannotBeNegativeZero() be aware of the nsz fast-math flag X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=85893f48a6994d71414773175440c421e5341810;p=oota-llvm.git Have CannotBeNegativeZero() be aware of the nsz fast-math flag git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@169452 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Analysis/ValueTracking.cpp b/lib/Analysis/ValueTracking.cpp index 47b1db6425b..eee231df8c9 100644 --- a/lib/Analysis/ValueTracking.cpp +++ b/lib/Analysis/ValueTracking.cpp @@ -1312,7 +1312,12 @@ bool llvm::CannotBeNegativeZero(const Value *V, unsigned Depth) { const Operator *I = dyn_cast(V); if (I == 0) return false; - + + // Check if the nsz fast-math flag is set + if (const FPMathOperator *FPO = dyn_cast(I)) + if (FPO->hasNoSignedZeros()) + return true; + // (add x, 0.0) is guaranteed to return +0.0, not -0.0. if (I->getOpcode() == Instruction::FAdd && isa(I->getOperand(1)) &&