aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Analysis/ValueTracking.cpp
diff options
context:
space:
mode:
authorMatt Arsenault <Matthew.Arsenault@amd.com>2023-04-13 10:15:15 -0400
committerMatt Arsenault <arsenm2@gmail.com>2023-04-19 20:11:33 -0400
commit02f647f8923c29f0a0352f9ef128e51b7bf28a2c (patch)
treebf8f73e0b147a9d6cddec767398a844d4b486c80 /llvm/lib/Analysis/ValueTracking.cpp
parentf6d79ad9eba4815ed4381106333e0e285f89ad02 (diff)
downloadllvm-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.cpp15
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;
}