aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Analysis/ValueTracking.cpp
diff options
context:
space:
mode:
authorMatt Arsenault <Matthew.Arsenault@amd.com>2023-04-08 14:35:15 -0400
committerMatt Arsenault <arsenm2@gmail.com>2023-04-13 14:44:34 -0400
commit4d044bfb33980a3453c9cd456c261750f1971b8a (patch)
treecfe92cfdef1d31c8c5f2663f3213e5370cadc3be /llvm/lib/Analysis/ValueTracking.cpp
parentd6f221869c1d1bf11cd2111efd368077684c6657 (diff)
downloadllvm-4d044bfb33980a3453c9cd456c261750f1971b8a.zip
llvm-4d044bfb33980a3453c9cd456c261750f1971b8a.tar.gz
llvm-4d044bfb33980a3453c9cd456c261750f1971b8a.tar.bz2
ValueTracking: Handle no-nan check for computeKnownFPClass for fmul
Copy the logic from isKnownNeverNaN for fadd/fsub. Leave the extension to handle the zero case for a future change.
Diffstat (limited to 'llvm/lib/Analysis/ValueTracking.cpp')
-rw-r--r--llvm/lib/Analysis/ValueTracking.cpp16
1 files changed, 16 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/ValueTracking.cpp b/llvm/lib/Analysis/ValueTracking.cpp
index af82276..8ff71de 100644
--- a/llvm/lib/Analysis/ValueTracking.cpp
+++ b/llvm/lib/Analysis/ValueTracking.cpp
@@ -4458,6 +4458,22 @@ void computeKnownFPClass(const Value *V, const APInt &DemandedElts,
break;
}
+ case Instruction::FMul: {
+ KnownFPClass KnownLHS, KnownRHS;
+ computeKnownFPClass(Op->getOperand(1), DemandedElts, fcNan | fcInf,
+ KnownRHS, Depth + 1, Q, TLI);
+ if (KnownRHS.isKnownNeverNaN() && KnownRHS.isKnownNeverInfinity()) {
+ computeKnownFPClass(Op->getOperand(0), DemandedElts, fcNan | fcInf,
+ KnownLHS, Depth + 1, Q, TLI);
+
+ // Zero multiplied with infinity produces NaN.
+ // FIXME: If neither side can be zero fmul never produces NaN.
+ if (KnownLHS.isKnownNeverNaN() && KnownLHS.isKnownNeverInfinity())
+ Known.knownNot(fcNan);
+ }
+
+ break;
+ }
case Instruction::SIToFP:
case Instruction::UIToFP: {
// Cannot produce nan