[X86] Don't report gather is legal on Skylake CPUs when AVX2/AVX512 is disabled....
authorCraig Topper <craig.topper@intel.com>
Sat, 25 Nov 2017 18:09:37 +0000 (18:09 +0000)
committerCraig Topper <craig.topper@intel.com>
Sat, 25 Nov 2017 18:09:37 +0000 (18:09 +0000)
commitea37e201ec2f9c3d8b2c9bb37ff48cacdd992f55
tree6bebfa5efe92abba04700e0a8ba456b2e9e7def6
parente7426556c16d86d52356b23538708dbea2008a76
[X86] Don't report gather is legal on Skylake CPUs when AVX2/AVX512 is disabled. Allow gather on SKX/CNL/ICL when AVX512 is disabled by using AVX2 instructions.

Summary:
This adds a new fast gather feature bit to cover all CPUs that support fast gather that we can use independent of whether the AVX512 feature is enabled. I'm only using this new bit to qualify AVX2 codegen. AVX512 is still implicitly assuming fast gather to keep tests working and to match the scatter behavior.

Test command lines have been added for these two cases.

Reviewers: magabari, delena, RKSimon, zvi

Reviewed By: RKSimon

Subscribers: llvm-commits

Differential Revision: https://reviews.llvm.org/D40282

llvm-svn: 318983
llvm/lib/Target/X86/X86.td
llvm/lib/Target/X86/X86Subtarget.cpp
llvm/lib/Target/X86/X86Subtarget.h
llvm/lib/Target/X86/X86TargetTransformInfo.cpp
llvm/test/CodeGen/X86/avx2-masked-gather.ll