diff options
author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2023-04-13 10:15:15 -0400 |
---|---|---|
committer | Matt Arsenault <arsenm2@gmail.com> | 2023-04-19 20:11:33 -0400 |
commit | 02f647f8923c29f0a0352f9ef128e51b7bf28a2c (patch) | |
tree | bf8f73e0b147a9d6cddec767398a844d4b486c80 /llvm/lib/Analysis/ValueTracking.cpp | |
parent | f6d79ad9eba4815ed4381106333e0e285f89ad02 (diff) | |
download | llvm-02f647f8923c29f0a0352f9ef128e51b7bf28a2c.zip llvm-02f647f8923c29f0a0352f9ef128e51b7bf28a2c.tar.gz llvm-02f647f8923c29f0a0352f9ef128e51b7bf28a2c.tar.bz2 |
ValueTracking: Handle sign bit of constrained sitofp/uitofp
This is for parity with CannotBeNegativeZero which is close to
droppable.
Diffstat (limited to 'llvm/lib/Analysis/ValueTracking.cpp')
-rw-r--r-- | llvm/lib/Analysis/ValueTracking.cpp | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/llvm/lib/Analysis/ValueTracking.cpp b/llvm/lib/Analysis/ValueTracking.cpp index db16c0c..f76e373 100644 --- a/llvm/lib/Analysis/ValueTracking.cpp +++ b/llvm/lib/Analysis/ValueTracking.cpp @@ -4505,7 +4505,8 @@ void computeKnownFPClass(const Value *V, const APInt &DemandedElts, } case Instruction::Call: { if (const IntrinsicInst *II = dyn_cast<IntrinsicInst>(Op)) { - switch (II->getIntrinsicID()) { + const Intrinsic::ID IID = II->getIntrinsicID(); + switch (IID) { case Intrinsic::fabs: computeKnownFPClass(II->getArgOperand(0), DemandedElts, InterestedClasses, Known, Depth + 1, Q, TLI); @@ -4576,6 +4577,18 @@ void computeKnownFPClass(const Value *V, const APInt &DemandedElts, InterestedClasses, Known, Depth + 1, Q, TLI); break; } + case Intrinsic::experimental_constrained_sitofp: + case Intrinsic::experimental_constrained_uitofp: + // Cannot produce nan + Known.knownNot(fcNan); + + // sitofp and uitofp turn into +0.0 for zero. + Known.knownNot(fcNegZero); + if (IID == Intrinsic::experimental_constrained_uitofp) + Known.signBitIsZero(); + + // TODO: Copy inf handling from instructions + break; default: break; } |