[llvm] 59138a6 - [DAGCombiner] Cleanup MatchFunnelPosNeg by using SDPatternMatch matchers (#129482)
via llvm-commits
llvm-commits at lists.llvm.org
Sun Mar 2 23:35:42 PST 2025
Author: Huibin Wang
Date: 2025-03-03T14:35:38+07:00
New Revision: 59138a603fca2a4e848ecf97af81c61559e9301d
URL: https://github.com/llvm/llvm-project/commit/59138a603fca2a4e848ecf97af81c61559e9301d
DIFF: https://github.com/llvm/llvm-project/commit/59138a603fca2a4e848ecf97af81c61559e9301d.diff
LOG: [DAGCombiner] Cleanup MatchFunnelPosNeg by using SDPatternMatch matchers (#129482)
Fixes issue: https://github.com/llvm/llvm-project/issues/129034
Added:
Modified:
llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
Removed:
################################################################################
diff --git a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
index 0d6dc61434666..ef6bf142b306d 100644
--- a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
+++ b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
@@ -8512,39 +8512,33 @@ SDValue DAGCombiner::MatchFunnelPosNeg(SDValue N0, SDValue N1, SDValue Pos,
// so for now just use the PosOpcode case if its legal.
// TODO: When can we use the NegOpcode case?
if (PosOpcode == ISD::FSHL && isPowerOf2_32(EltBits)) {
- auto IsBinOpImm = [](SDValue Op, unsigned BinOpc, unsigned Imm) {
- if (Op.getOpcode() != BinOpc)
- return false;
- ConstantSDNode *Cst = isConstOrConstSplat(Op.getOperand(1));
- return Cst && (Cst->getAPIntValue() == Imm);
- };
-
+ SDValue X;
// fold (or (shl x0, y), (srl (srl x1, 1), (xor y, 31)))
// -> (fshl x0, x1, y)
- if (IsBinOpImm(N1, ISD::SRL, 1) &&
- IsBinOpImm(InnerNeg, ISD::XOR, EltBits - 1) &&
- InnerPos == InnerNeg.getOperand(0) &&
+ if (sd_match(N1, m_Srl(m_Value(X), m_One())) &&
+ sd_match(InnerNeg,
+ m_Xor(m_Specific(InnerPos), m_SpecificInt(EltBits - 1))) &&
TLI.isOperationLegalOrCustom(ISD::FSHL, VT)) {
- return DAG.getNode(ISD::FSHL, DL, VT, N0, N1.getOperand(0), Pos);
+ return DAG.getNode(ISD::FSHL, DL, VT, N0, X, Pos);
}
// fold (or (shl (shl x0, 1), (xor y, 31)), (srl x1, y))
// -> (fshr x0, x1, y)
- if (IsBinOpImm(N0, ISD::SHL, 1) &&
- IsBinOpImm(InnerPos, ISD::XOR, EltBits - 1) &&
- InnerNeg == InnerPos.getOperand(0) &&
+ if (sd_match(N0, m_Shl(m_Value(X), m_One())) &&
+ sd_match(InnerPos,
+ m_Xor(m_Specific(InnerNeg), m_SpecificInt(EltBits - 1))) &&
TLI.isOperationLegalOrCustom(ISD::FSHR, VT)) {
- return DAG.getNode(ISD::FSHR, DL, VT, N0.getOperand(0), N1, Neg);
+ return DAG.getNode(ISD::FSHR, DL, VT, X, N1, Neg);
}
// fold (or (shl (add x0, x0), (xor y, 31)), (srl x1, y))
// -> (fshr x0, x1, y)
// TODO: Should add(x,x) -> shl(x,1) be a general DAG canonicalization?
- if (N0.getOpcode() == ISD::ADD && N0.getOperand(0) == N0.getOperand(1) &&
- IsBinOpImm(InnerPos, ISD::XOR, EltBits - 1) &&
- InnerNeg == InnerPos.getOperand(0) &&
+ if (sd_match(N0, m_Add(m_Value(X), m_Deferred(X))) &&
+ sd_match(InnerPos,
+ m_Xor(m_Specific(InnerNeg), m_SpecificInt(EltBits - 1))) &&
TLI.isOperationLegalOrCustom(ISD::FSHR, VT)) {
- return DAG.getNode(ISD::FSHR, DL, VT, N0.getOperand(0), N1, Neg);
+ return DAG.getNode(ISD::FSHR, DL, VT, X, N1, Neg);
}
}
More information about the llvm-commits
mailing list