diff options
| author | Simon Pilgrim <llvm-dev@redking.me.uk> | 2018-11-14 11:26:35 +0000 | 
|---|---|---|
| committer | Simon Pilgrim <llvm-dev@redking.me.uk> | 2018-11-14 11:26:35 +0000 | 
| commit | 7501780ec68196355b5d39869acd68016c60b427 (patch) | |
| tree | 862a8576123e50ca4297116e546cf0366c2a5464 /llvm/lib | |
| parent | 18e98645014feb187c11c87b5bd291641e31afc5 (diff) | |
| download | bcm5719-llvm-7501780ec68196355b5d39869acd68016c60b427.tar.gz bcm5719-llvm-7501780ec68196355b5d39869acd68016c60b427.zip | |
[X86][AVX512] Remove constant pool shuffle decoding from SelectionDAG
This patch removes the last use of the constant pool shuffle decode helper and consistently uses the 'getTargetShuffleMaskIndices' versions instead. The constant pool versions are now purely used for assembly comments.
The avx512vbmi intrinsic upgrades had to be altered as they were being decoded as broadcasts, similar to what I fixed in rL346032. I don't think the change is critical - although its annoying that we lose the {k}{z} instruction test coverage as they are tricky to generate....
Differential Revision: https://reviews.llvm.org/D54083
llvm-svn: 346850
Diffstat (limited to 'llvm/lib')
| -rw-r--r-- | llvm/lib/Target/X86/X86ISelLowering.cpp | 6 | 
1 files changed, 3 insertions, 3 deletions
| diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp index 12cec3bae10..d1421373517 100644 --- a/llvm/lib/Target/X86/X86ISelLowering.cpp +++ b/llvm/lib/Target/X86/X86ISelLowering.cpp @@ -19,7 +19,6 @@  #include "X86InstrBuilder.h"  #include "X86IntrinsicsInfo.h"  #include "X86MachineFunctionInfo.h" -#include "X86ShuffleDecodeConstantPool.h"  #include "X86TargetMachine.h"  #include "X86TargetObjectFile.h"  #include "llvm/ADT/SmallBitVector.h" @@ -6147,8 +6146,9 @@ static bool getTargetShuffleMask(SDNode *N, MVT VT, bool AllowSentinelZero,      Ops.push_back(N->getOperand(0));      Ops.push_back(N->getOperand(2));      SDValue MaskNode = N->getOperand(1); -    if (auto *C = getTargetConstantFromNode(MaskNode)) { -      DecodeVPERMV3Mask(C, MaskEltSize, VT.getSizeInBits(), Mask); +    if (getTargetShuffleMaskIndices(MaskNode, MaskEltSize, RawMask, +                                    RawUndefs)) { +      DecodeVPERMV3Mask(RawMask, RawUndefs, Mask);        break;      }      return false; | 

