[llvm] [ValueTracking] Handle recursive phis in knownFPClass (PR #114008)

Yingwei Zheng via llvm-commits llvm-commits at lists.llvm.org
Tue Oct 29 01:07:26 PDT 2024


================
@@ -5999,6 +5999,21 @@ void computeKnownFPClass(const Value *V, const APInt &DemandedElts,
         if (IncValue == P)
           continue;
 
+        // If the Use is a select of this phi, use the fp class of the other
+        // operand to break the recursion.
+        Value *V;
+        if (match(IncValue, m_Select(m_Value(), m_Specific(P), m_Value(V))) ||
+            match(IncValue, m_Select(m_Value(), m_Value(V), m_Specific(P))))
+          IncValue = V;
+        // Same around 2-operand phi nodes
+        if (auto *IncPhi = dyn_cast<PHINode>(IncValue);
+            IncPhi && IncPhi->getNumIncomingValues() == 2) {
+          if (IncPhi->getIncomingValue(0) == P)
+            IncValue = IncPhi->getIncomingValue(1);
----------------
dtcxzyw wrote:

Should we update `CtxI` to `IncPhi->getIncomingBlock(1)->getTerminator()`?


https://github.com/llvm/llvm-project/pull/114008


More information about the llvm-commits mailing list