diff options
| author | Sanjay Patel <spatel@rotateright.com> | 2019-05-12 14:43:20 +0000 | 
|---|---|---|
| committer | Sanjay Patel <spatel@rotateright.com> | 2019-05-12 14:43:20 +0000 | 
| commit | a09e6868218b3a26df7b43aaf2458899e8e8d240 (patch) | |
| tree | dfe3672d445275e938133f666803c6a1d5ee43d4 /llvm/lib | |
| parent | de7a30cb0a0f911aba1b43c39598860475fcfe64 (diff) | |
| download | bcm5719-llvm-a09e6868218b3a26df7b43aaf2458899e8e8d240.tar.gz bcm5719-llvm-a09e6868218b3a26df7b43aaf2458899e8e8d240.zip | |
[DAGCombiner] try to move bitcast after extract_subvector
I noticed that we were failing to narrow an x86 ymm math op in a case similar
to the 'madd' test diff. That is because a bitcast is sitting between the math
and the extract subvector and thwarting our pattern matching for narrowing:
       t56: v8i32 = add t59, t58
      t68: v4i64 = bitcast t56
    t73: v2i64 = extract_subvector t68, Constant:i64<2>
  t96: v4i32 = bitcast t73
There are a few wins and neutral diffs in the other tests.
Differential Revision: https://reviews.llvm.org/D61806
llvm-svn: 360541
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp | 24 | 
1 files changed, 24 insertions, 0 deletions
| diff --git a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp index 1d8f530f4c5..ed805e0750f 100644 --- a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp @@ -17583,6 +17583,30 @@ SDValue DAGCombiner::visitEXTRACT_SUBVECTOR(SDNode *N) {      }    } +  // Try to move vector bitcast after extract_subv by scaling extraction index: +  // extract_subv (bitcast X), Index --> bitcast (extract_subv X, Index') +  if (isa<ConstantSDNode>(Index) && V.getOpcode() == ISD::BITCAST && +      V.getOperand(0).getValueType().isVector()) { +    SDValue SrcOp = V.getOperand(0); +    EVT SrcVT = SrcOp.getValueType(); +    unsigned SrcNumElts = SrcVT.getVectorNumElements(); +    unsigned DestNumElts = V.getValueType().getVectorNumElements(); +    if ((SrcNumElts % DestNumElts) == 0) { +      unsigned SrcDestRatio = SrcNumElts / DestNumElts; +      unsigned NewExtNumElts = NVT.getVectorNumElements() * SrcDestRatio; +      EVT NewExtVT = EVT::getVectorVT(*DAG.getContext(), SrcVT.getScalarType(), +                                      NewExtNumElts); +      if (TLI.isOperationLegalOrCustom(ISD::EXTRACT_SUBVECTOR, NewExtVT)) { +        unsigned IndexValScaled = N->getConstantOperandVal(1) * SrcDestRatio; +        SDLoc DL(N); +        SDValue NewIndex = DAG.getIntPtrConstant(IndexValScaled, DL); +        SDValue NewExtract = DAG.getNode(ISD::EXTRACT_SUBVECTOR, DL, NewExtVT, +                                         V.getOperand(0), NewIndex); +        return DAG.getBitcast(NVT, NewExtract); +      } +    } +  } +    // Combine:    //    (extract_subvec (concat V1, V2, ...), i)    // Into: | 

