diff options
| author | Benjamin Kramer <benny.kra@googlemail.com> | 2019-05-29 19:24:19 +0000 | 
|---|---|---|
| committer | Benjamin Kramer <benny.kra@googlemail.com> | 2019-05-29 19:24:19 +0000 | 
| commit | 107f8d98730c9f38f28b462f0e11901274f93cdd (patch) | |
| tree | cf97a6f27871c47b41ef88a81406a35f9be063ec /llvm/lib/CodeGen/SelectionDAG | |
| parent | 1d7ca677697f5b6bb40011e7fc962bb1a158e96a (diff) | |
| download | bcm5719-llvm-107f8d98730c9f38f28b462f0e11901274f93cdd.tar.gz bcm5719-llvm-107f8d98730c9f38f28b462f0e11901274f93cdd.zip  | |
[DAGCombiner] Replace gathers with a zero mask with the passthru value
These can be created by the legalizer when splitting a larger gather.
See https://llvm.org/PR42055 for a motivating example.
Differential Revision: https://reviews.llvm.org/D62613
llvm-svn: 362015
Diffstat (limited to 'llvm/lib/CodeGen/SelectionDAG')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp | 10 | 
1 files changed, 7 insertions, 3 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp index 48c918051bb..1518efd1256 100644 --- a/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/DAGCombiner.cpp @@ -8084,13 +8084,17 @@ SDValue DAGCombiner::visitMSTORE(SDNode *N) {  }  SDValue DAGCombiner::visitMGATHER(SDNode *N) { -  if (Level >= AfterLegalizeTypes) -    return SDValue(); -    MaskedGatherSDNode *MGT = cast<MaskedGatherSDNode>(N);    SDValue Mask = MGT->getMask();    SDLoc DL(N); +  // Zap gathers with a zero mask. +  if (ISD::isBuildVectorAllZeros(Mask.getNode())) +    return CombineTo(N, MGT->getPassThru(), MGT->getChain()); + +  if (Level >= AfterLegalizeTypes) +    return SDValue(); +    // If the MGATHER result requires splitting and the mask is provided by a    // SETCC, then split both nodes and its operands before legalization. This    // prevents the type legalizer from unrolling SETCC into scalar comparisons  | 

