[llvm] [DAGCombiner] Add support for scalarising extracts of a vector setcc (PR #116031)

Paul Walker via llvm-commits llvm-commits at lists.llvm.org
Wed Nov 20 10:28:38 PST 2024


================
@@ -22769,13 +22765,46 @@ static SDValue scalarizeExtractedBinop(SDNode *ExtElt, SelectionDAG &DAG,
       ISD::isConstantSplatVector(Op1.getNode(), SplatVal)) {
     // extractelt (binop X, C), IndexC --> binop (extractelt X, IndexC), C'
     // extractelt (binop C, X), IndexC --> binop C', (extractelt X, IndexC)
-    EVT VT = ExtElt->getValueType(0);
-    SDValue Ext0 = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, VT, Op0, Index);
-    SDValue Ext1 = DAG.getNode(ISD::EXTRACT_VECTOR_ELT, DL, VT, Op1, Index);
-    return DAG.getNode(Vec.getOpcode(), DL, VT, Ext0, Ext1);
+    // extractelt (setcc X, C, op), IndexC -> setcc (extractelt X, IndexC)), C
+    // extractelt (setcc C, X, op), IndexC -> setcc (extractelt IndexC, X)), C
----------------
paulwalker-arm wrote:

```suggestion
    // extractelt (setcc C, X, op), IndexC -> setcc C, (extractelt X, IndexC))
```
That said, I don't think this, now common, function needs to call out every operation.  Perhaps just change `binop` to `op` to make the original comment more general?

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


More information about the llvm-commits mailing list