[llvm-commits] [llvm] r137310 - /llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
Nadav Rotem
nadav.rotem at intel.com
Thu Aug 11 09:49:36 PDT 2011
Author: nadav
Date: Thu Aug 11 11:49:36 2011
New Revision: 137310
URL: http://llvm.org/viewvc/llvm-project?rev=137310&view=rev
Log:
[AVX] When joining two XMM registers into a YMM register, make sure that the
lower XMM register gets in first. This will allow the SUBREG pattern to
elliminate the first vector insertion.
Modified:
llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
Modified: llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp?rev=137310&r1=137309&r2=137310&view=diff
==============================================================================
--- llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp (original)
+++ llvm/trunk/lib/CodeGen/SelectionDAG/DAGCombiner.cpp Thu Aug 11 11:49:36 2011
@@ -213,6 +213,7 @@
SDValue visitLOAD(SDNode *N);
SDValue visitSTORE(SDNode *N);
SDValue visitINSERT_VECTOR_ELT(SDNode *N);
+ SDValue visitINSERT_SUBVECTOR(SDNode *N);
SDValue visitEXTRACT_VECTOR_ELT(SDNode *N);
SDValue visitBUILD_VECTOR(SDNode *N);
SDValue visitCONCAT_VECTORS(SDNode *N);
@@ -1102,6 +1103,7 @@
case ISD::LOAD: return visitLOAD(N);
case ISD::STORE: return visitSTORE(N);
case ISD::INSERT_VECTOR_ELT: return visitINSERT_VECTOR_ELT(N);
+ case ISD::INSERT_SUBVECTOR: return visitINSERT_SUBVECTOR(N);
case ISD::EXTRACT_VECTOR_ELT: return visitEXTRACT_VECTOR_ELT(N);
case ISD::BUILD_VECTOR: return visitBUILD_VECTOR(N);
case ISD::CONCAT_VECTORS: return visitCONCAT_VECTORS(N);
@@ -7136,6 +7138,36 @@
}
}
+SDValue DAGCombiner::visitINSERT_SUBVECTOR(SDNode* N) {
+ DebugLoc dl = N->getDebugLoc();
+ EVT VT = N->getValueType(0);
+ // When inserting a subvector into a vector, make sure to start
+ // inserting starting the Zero index. This will allow making the
+ // first insertion using a subreg insertion, and save a register.
+ SDValue V = N->getOperand(0);
+ if (V->getOpcode() == ISD::INSERT_SUBVECTOR && V->hasOneUse()) {
+ ConstantSDNode *N_Idx = dyn_cast<ConstantSDNode>(N->getOperand(2));
+ ConstantSDNode *V_Idx = dyn_cast<ConstantSDNode>(V->getOperand(2));
+ uint64_t Nc = N_Idx->getZExtValue();
+ uint64_t Vc = V_Idx->getZExtValue();
+
+ // Reorder insertion to vector
+ if (Nc < Vc) {
+ SDValue NewV = DAG.getNode(ISD::INSERT_SUBVECTOR, dl, VT,
+ V->getOperand(0),
+ N->getOperand(1),
+ N->getOperand(2));
+ return DAG.getNode(ISD::INSERT_SUBVECTOR, dl, VT,
+ NewV,
+ V->getOperand(1),
+ V->getOperand(2));
+ }
+ }
+
+ return SDValue();
+}
+
+
/// XformToShuffleWithZero - Returns a vector_shuffle if it able to transform
/// an AND to a vector_shuffle with the destination vector and a zero vector.
/// e.g. AND V, <0xffffffff, 0, 0xffffffff, 0>. ==>
More information about the llvm-commits
mailing list