diff options
author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2023-04-08 14:35:15 -0400 |
---|---|---|
committer | Matt Arsenault <arsenm2@gmail.com> | 2023-04-13 14:44:34 -0400 |
commit | 4d044bfb33980a3453c9cd456c261750f1971b8a (patch) | |
tree | cfe92cfdef1d31c8c5f2663f3213e5370cadc3be /llvm/lib/Analysis/ValueTracking.cpp | |
parent | d6f221869c1d1bf11cd2111efd368077684c6657 (diff) | |
download | llvm-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.cpp | 16 |
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 |