[PATCH] D137688: [CodeGen] Refactor visitSCALAR_TO_VECTOR. NFC.
Han-Kuan Chen via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Nov 22 01:29:19 PST 2022
This revision was landed with ongoing or failed builds.
This revision was automatically updated to reflect the committed changes.
Closed by commit rGcaa9f63022d2: [CodeGen] Refactor visitSCALAR_TO_VECTOR. NFC. (authored by HanKuanChen).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D137688/new/
https://reviews.llvm.org/D137688
Files:
llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
Index: llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
===================================================================
--- llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
+++ llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
@@ -23536,36 +23536,26 @@
DAG.isSafeToSpeculativelyExecute(Opcode) && hasOperation(Opcode, VT)) {
// Match an extract element and get a shuffle mask equivalent.
SmallVector<int, 8> ShufMask(VT.getVectorNumElements(), -1);
- auto getShuffleMaskForExtElt = [&](SDValue EE) {
- if (EE.getOpcode() == ISD::EXTRACT_VECTOR_ELT &&
+
+ for (int i : {0, 1}) {
+ // s2v (bo (extelt V, Idx), C) --> shuffle (bo V, C'), {Idx, -1, -1...}
+ // s2v (bo C, (extelt V, Idx)) --> shuffle (bo C', V), {Idx, -1, -1...}
+ SDValue EE = Scalar.getOperand(i);
+ auto *C = dyn_cast<ConstantSDNode>(Scalar.getOperand(i ? 0 : 1));
+ if (C && EE.getOpcode() == ISD::EXTRACT_VECTOR_ELT &&
EE.getOperand(0).getValueType() == VT &&
isa<ConstantSDNode>(EE.getOperand(1))) {
// Mask = {ExtractIndex, undef, undef....}
ShufMask[0] = EE.getConstantOperandVal(1);
// Make sure the shuffle is legal if we are crossing lanes.
- return TLI.isShuffleMaskLegal(ShufMask, VT);
- }
- return false;
- };
-
- // s2v (bo (extelt V, Idx), C) --> shuffle (bo V, C'), {Idx, -1, -1...}
- if (auto *C = dyn_cast<ConstantSDNode>(Scalar.getOperand(1))) {
- if (getShuffleMaskForExtElt(Scalar.getOperand(0))) {
- SDLoc DL(N);
- SDValue V = Scalar.getOperand(0).getOperand(0);
- SDValue VecC = DAG.getConstant(C->getAPIntValue(), DL, VT);
- SDValue VecBO = DAG.getNode(Opcode, DL, VT, V, VecC);
- return DAG.getVectorShuffle(VT, DL, VecBO, DAG.getUNDEF(VT), ShufMask);
- }
- }
- // s2v (bo C, (extelt V, Idx)) --> shuffle (bo C', V), {Idx, -1, -1...}
- if (auto *C = dyn_cast<ConstantSDNode>(Scalar.getOperand(0))) {
- if (getShuffleMaskForExtElt(Scalar.getOperand(1))) {
- SDLoc DL(N);
- SDValue V = Scalar.getOperand(1).getOperand(0);
- SDValue VecC = DAG.getConstant(C->getAPIntValue(), DL, VT);
- SDValue VecBO = DAG.getNode(Opcode, DL, VT, VecC, V);
- return DAG.getVectorShuffle(VT, DL, VecBO, DAG.getUNDEF(VT), ShufMask);
+ if (TLI.isShuffleMaskLegal(ShufMask, VT)) {
+ SDLoc DL(N);
+ SDValue V[] = {EE.getOperand(0),
+ DAG.getConstant(C->getAPIntValue(), DL, VT)};
+ SDValue VecBO = DAG.getNode(Opcode, DL, VT, V[i], V[1 - i]);
+ return DAG.getVectorShuffle(VT, DL, VecBO, DAG.getUNDEF(VT),
+ ShufMask);
+ }
}
}
}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D137688.477107.patch
Type: text/x-patch
Size: 2736 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20221122/56583517/attachment.bin>
More information about the llvm-commits
mailing list