diff options
author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2023-04-08 22:54:30 -0400 |
---|---|---|
committer | Matt Arsenault <arsenm2@gmail.com> | 2023-04-14 17:41:26 -0400 |
commit | 3dabcdc78b718db8136e27c8bec7b99eeabac5bf (patch) | |
tree | 4812beaec00f963bd219db856fd257355ab22f7a /llvm/lib/Analysis/ValueTracking.cpp | |
parent | f3c299fc52b9d107c6e29ec38b18626f5223a391 (diff) | |
download | llvm-3dabcdc78b718db8136e27c8bec7b99eeabac5bf.zip llvm-3dabcdc78b718db8136e27c8bec7b99eeabac5bf.tar.gz llvm-3dabcdc78b718db8136e27c8bec7b99eeabac5bf.tar.bz2 |
ValueTracking: Implement computeKnownFPClass for llvm.trunc
Diffstat (limited to 'llvm/lib/Analysis/ValueTracking.cpp')
-rw-r--r-- | llvm/lib/Analysis/ValueTracking.cpp | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/llvm/lib/Analysis/ValueTracking.cpp b/llvm/lib/Analysis/ValueTracking.cpp index 51f8894..4a79f52 100644 --- a/llvm/lib/Analysis/ValueTracking.cpp +++ b/llvm/lib/Analysis/ValueTracking.cpp @@ -4494,6 +4494,25 @@ void computeKnownFPClass(const Value *V, const APInt &DemandedElts, break; } + case Intrinsic::trunc: { + KnownFPClass KnownSrc; + computeKnownFPClass(II->getArgOperand(0), DemandedElts, + InterestedClasses, KnownSrc, Depth + 1, Q, TLI); + + // Integer results cannot be subnormal. + Known.knownNot(fcSubnormal); + + // trunc passes through infinities. + if (KnownSrc.isKnownNeverPosInfinity()) + Known.knownNot(fcPosInf); + if (KnownSrc.isKnownNeverNegInfinity()) + Known.knownNot(fcNegInf); + + // Non-constrained intrinsics do not guarantee signaling nan quieting. + if (KnownSrc.isKnownNeverNaN()) + Known.knownNot(fcNan); + break; + } default: break; } |