summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorCraig Topper <craig.topper@gmail.com>2016-09-06 00:31:10 +0000
committerCraig Topper <craig.topper@gmail.com>2016-09-06 00:31:10 +0000
commit62d0a5e7d36e4e0595aff41b3d56d0317b1c8e5f (patch)
treed635c2c6ea48561e608929bc4de05462ca143365 /llvm/lib
parenta6519b1d543654b9b6a694ed3288e393612d3589 (diff)
downloadbcm5719-llvm-62d0a5e7d36e4e0595aff41b3d56d0317b1c8e5f.tar.gz
bcm5719-llvm-62d0a5e7d36e4e0595aff41b3d56d0317b1c8e5f.zip
[AVX-512] Fix v8i64 shift by immediate lowering on 32-bit targets.
llvm-svn: 280684
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Target/X86/X86ISelLowering.cpp3
1 files changed, 2 insertions, 1 deletions
diff --git a/llvm/lib/Target/X86/X86ISelLowering.cpp b/llvm/lib/Target/X86/X86ISelLowering.cpp
index ccf0fca3d58..862758e97bd 100644
--- a/llvm/lib/Target/X86/X86ISelLowering.cpp
+++ b/llvm/lib/Target/X86/X86ISelLowering.cpp
@@ -20215,7 +20215,8 @@ static SDValue LowerScalarImmediateShift(SDValue Op, SelectionDAG &DAG,
// Special case in 32-bit mode, where i64 is expanded into high and low parts.
if (!Subtarget.is64Bit() && !Subtarget.hasXOP() &&
- (VT == MVT::v2i64 || (Subtarget.hasInt256() && VT == MVT::v4i64))) {
+ (VT == MVT::v2i64 || (Subtarget.hasInt256() && VT == MVT::v4i64) ||
+ (Subtarget.hasAVX512() && VT == MVT::v8i64))) {
// Peek through any splat that was introduced for i64 shift vectorization.
int SplatIndex = -1;
OpenPOWER on IntegriCloud