[llvm] [DAG] Fold nested add(add(reduce(a), b), add(reduce(c), d)) (PR #115150)

Simon Pilgrim via llvm-commits llvm-commits at lists.llvm.org
Wed Nov 6 03:57:01 PST 2024


================
@@ -1329,6 +1329,38 @@ SDValue DAGCombiner::reassociateReduction(unsigned RedOpc, unsigned Opc,
                        DAG.getNode(Opc, DL, N0.getOperand(0).getValueType(),
                                    N0.getOperand(0), N1.getOperand(0)));
   }
+
+  // Reassociate add(add(vecreduce(a), b), add(vecreduce(c), d)) into
+  // add(vecreduce(add(a, c)), add(b, d)), to combine the reductions into a
+  // single node.
+  if (N0.getOpcode() == Opc && N1.getOpcode() == Opc && N0->hasOneUse() &&
+      N1->hasOneUse()) {
+    SDValue N00 = N0.getOperand(0);
+    SDValue N01 = N0.getOperand(1);
+    if (N00.getOpcode() != RedOpc && N01.getOpcode() == RedOpc)
+      std::swap(N00, N01);
+    if (N00.getOpcode() == RedOpc && N01.getOpcode() != RedOpc &&
+        N00->hasOneUse()) {
----------------
RKSimon wrote:

I'm pretty sure you can use sd_match to handle all of this matching (including the operand swapping).

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


More information about the llvm-commits mailing list