diff options
author | Craig Topper <craig.topper@intel.com> | 2017-11-22 20:05:51 +0000 |
---|---|---|
committer | Craig Topper <craig.topper@intel.com> | 2017-11-22 20:05:51 +0000 |
commit | e15cc1687399749e0ff7c1bd38850e02dbc8f090 (patch) | |
tree | 44bd700dda83a95f9b1d18f79e2e063941e34db2 /llvm/lib/Target | |
parent | 7c08dc3fd0968d96636a2232e44dce645b1f1dfa (diff) | |
download | bcm5719-llvm-e15cc1687399749e0ff7c1bd38850e02dbc8f090.tar.gz bcm5719-llvm-e15cc1687399749e0ff7c1bd38850e02dbc8f090.zip |
[X86] Sink the MGATHER setOperationActions for AVX2 into the AVX block where most of the rest of the AVX2 legalization lives.
llvm-svn: 318869
Diffstat (limited to 'llvm/lib/Target')
-rw-r--r-- | llvm/lib/Target/X86/X86ISelLowering.cpp | 13 |
1 files changed, 6 insertions, 7 deletions
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp index d6436eeac68..80519e5aa52 100644 --- a/llvm/lib/Target/X86/X86ISelLowering.cpp +++ b/llvm/lib/Target/X86/X86ISelLowering.cpp @@ -970,13 +970,6 @@ X86TargetLowering::X86TargetLowering(const X86TargetMachine &TM, setOperationAction(ISD::BITREVERSE, VT, Custom); } - // Special handling for masked gather of 2 elements - if (Subtarget.hasAVX2()) { - for (auto VT : { MVT::v4i32, MVT::v8i32, MVT::v2i64, MVT::v4i64, - MVT::v4f32, MVT::v8f32, MVT::v2f64, MVT::v4f64 }) - setOperationAction(ISD::MGATHER, VT, Custom); - } - if (!Subtarget.useSoftFloat() && Subtarget.hasFp256()) { bool HasInt256 = Subtarget.hasInt256(); @@ -1139,6 +1132,12 @@ X86TargetLowering::X86TargetLowering(const X86TargetMachine &TM, setOperationPromotedToType(ISD::LOAD, VT, MVT::v4i64); setOperationPromotedToType(ISD::SELECT, VT, MVT::v4i64); } + + if (HasInt256) { + for (auto VT : { MVT::v4i32, MVT::v8i32, MVT::v2i64, MVT::v4i64, + MVT::v4f32, MVT::v8f32, MVT::v2f64, MVT::v4f64 }) + setOperationAction(ISD::MGATHER, VT, Custom); + } } if (!Subtarget.useSoftFloat() && Subtarget.hasAVX512()) { |