From 6717f9d90741b7ab4c14c9f27e80b03121309ab1 Mon Sep 17 00:00:00 2001 From: Chandler Carruth Date: Wed, 24 Sep 2014 01:24:44 +0000 Subject: [PATCH] [x86] Teach the new vector shuffle lowering to lower v8i32 shuffles with the native AVX2 instructions. Note that the test case is really frustrating here because VPERMD requires the mask to be in the register input and we don't produce a comment looking through that to the constant pool. I'm going to attempt to improve this in a subsequent commit, but not sure if I will succeed. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@218347 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Target/X86/X86ISelLowering.cpp | 55 +- test/CodeGen/X86/vector-shuffle-256-v8.ll | 863 +++++++++++++++------- 2 files changed, 646 insertions(+), 272 deletions(-) diff --git a/lib/Target/X86/X86ISelLowering.cpp b/lib/Target/X86/X86ISelLowering.cpp index 279c21db8b8..3ac4c6d5920 100644 --- a/lib/Target/X86/X86ISelLowering.cpp +++ b/lib/Target/X86/X86ISelLowering.cpp @@ -9544,11 +9544,56 @@ static SDValue lowerV8I32VectorShuffle(SDValue Op, SDValue V1, SDValue V2, assert(Mask.size() == 8 && "Unexpected mask size for v8 shuffle!"); assert(Subtarget->hasAVX2() && "We can only lower v8i32 with AVX2!"); - // FIXME: Actually implement this using AVX2!!! - V1 = DAG.getNode(ISD::BITCAST, DL, MVT::v8f32, V1); - V2 = DAG.getNode(ISD::BITCAST, DL, MVT::v8f32, V2); - return DAG.getNode(ISD::BITCAST, DL, MVT::v8i32, - DAG.getVectorShuffle(MVT::v8f32, DL, V1, V2, Mask)); + if (SDValue Blend = lowerVectorShuffleAsBlend(DL, MVT::v8i32, V1, V2, Mask, + Subtarget, DAG)) + return Blend; + + // If the shuffle mask is repeated in each 128-bit lane we can use more + // efficient instructions that mirror the shuffles across the two 128-bit + // lanes. + SmallVector RepeatedMask; + if (is128BitLaneRepeatedShuffleMask(MVT::v8i32, Mask, RepeatedMask)) { + assert(RepeatedMask.size() == 4 && "Unexpected repeated mask size!"); + if (isSingleInputShuffleMask(Mask)) + return DAG.getNode(X86ISD::PSHUFD, DL, MVT::v8i32, V1, + getV4X86ShuffleImm8ForMask(RepeatedMask, DAG)); + + // Use dedicated unpack instructions for masks that match their pattern. + if (isShuffleEquivalent(Mask, 0, 8, 1, 9)) + return DAG.getNode(X86ISD::UNPCKL, DL, MVT::v8i32, V1, V2); + if (isShuffleEquivalent(Mask, 2, 10, 3, 11)) + return DAG.getNode(X86ISD::UNPCKH, DL, MVT::v8i32, V1, V2); + } + + // If the shuffle patterns aren't repeated but it is a single input, directly + // generate a cross-lane VPERMD instruction. + if (isSingleInputShuffleMask(Mask)) { + SDValue VPermMask[8]; + for (int i = 0; i < 8; ++i) + VPermMask[i] = Mask[i] < 0 ? DAG.getUNDEF(MVT::i32) + : DAG.getConstant(Mask[i], MVT::i32); + return DAG.getNode( + X86ISD::VPERMV, DL, MVT::v8i32, + DAG.getNode(ISD::BUILD_VECTOR, DL, MVT::v8i32, VPermMask), V1); + } + + // Shuffle the input elements into the desired positions in V1 and V2 and + // blend them together. + int V1Mask[] = {-1, -1, -1, -1, -1, -1, -1, -1}; + int V2Mask[] = {-1, -1, -1, -1, -1, -1, -1, -1}; + int BlendMask[] = {-1, -1, -1, -1, -1, -1, -1, -1}; + for (int i = 0; i < 8; ++i) + if (Mask[i] >= 0 && Mask[i] < 8) { + V1Mask[i] = Mask[i]; + BlendMask[i] = i; + } else if (Mask[i] >= 8) { + V2Mask[i] = Mask[i] - 8; + BlendMask[i] = i + 8; + } + + V1 = DAG.getVectorShuffle(MVT::v8i32, DL, V1, DAG.getUNDEF(MVT::v8i32), V1Mask); + V2 = DAG.getVectorShuffle(MVT::v8i32, DL, V2, DAG.getUNDEF(MVT::v8i32), V2Mask); + return DAG.getVectorShuffle(MVT::v8i32, DL, V1, V2, BlendMask); } /// \brief Handle lowering of 16-lane 16-bit integer shuffles. diff --git a/test/CodeGen/X86/vector-shuffle-256-v8.ll b/test/CodeGen/X86/vector-shuffle-256-v8.ll index 566ce1ea158..af46e99d277 100644 --- a/test/CodeGen/X86/vector-shuffle-256-v8.ll +++ b/test/CodeGen/X86/vector-shuffle-256-v8.ll @@ -550,96 +550,148 @@ define <8 x float> @shuffle_v8f32_uuu3uu66(<8 x float> %a, <8 x float> %b) { } define <8 x i32> @shuffle_v8i32_00000000(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00000000 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,0,0] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm0, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00000000 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,0,0] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm0, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00000000 +; AVX2: # BB#0: +; AVX2-NEXT: vpxor %ymm1, %ymm1, %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00000010(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00000010 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # xmm1 = xmm0[0,0,0,0] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,1,0] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00000010 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # xmm1 = xmm0[0,0,0,0] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,1,0] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00000010 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI56_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00000200(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00000200 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # xmm1 = xmm0[0,0,0,0] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,2,0,0] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00000200 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # xmm1 = xmm0[0,0,0,0] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,2,0,0] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00000200 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI57_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00003000(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00003000 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # xmm1 = xmm0[0,0,0,0] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[3,0,0,0] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00003000 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # xmm1 = xmm0[0,0,0,0] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[3,0,0,0] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00003000 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI58_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00040000(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00040000 -; ALL: # BB#0: -; ALL-NEXT: vextractf128 $1, %ymm0, %xmm1 -; ALL-NEXT: vshufps {{.*}} # xmm1 = xmm1[0,0],xmm0[0,0] -; ALL-NEXT: vshufps {{.*}} # xmm1 = xmm0[0,0],xmm1[2,0] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,0,0] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00040000 +; AVX1: # BB#0: +; AVX1-NEXT: vextractf128 $1, %ymm0, %xmm1 +; AVX1-NEXT: vshufps {{.*}} # xmm1 = xmm1[0,0],xmm0[0,0] +; AVX1-NEXT: vshufps {{.*}} # xmm1 = xmm0[0,0],xmm1[2,0] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,0,0] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00040000 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI59_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00500000(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00500000 -; ALL: # BB#0: -; ALL-NEXT: vextractf128 $1, %ymm0, %xmm1 -; ALL-NEXT: vshufps {{.*}} # xmm1 = xmm1[1,0],xmm0[0,0] -; ALL-NEXT: vshufps {{.*}} # xmm1 = xmm0[0,0],xmm1[0,2] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,0,0] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00500000 +; AVX1: # BB#0: +; AVX1-NEXT: vextractf128 $1, %ymm0, %xmm1 +; AVX1-NEXT: vshufps {{.*}} # xmm1 = xmm1[1,0],xmm0[0,0] +; AVX1-NEXT: vshufps {{.*}} # xmm1 = xmm0[0,0],xmm1[0,2] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,0,0] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00500000 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI60_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_06000000(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_06000000 -; ALL: # BB#0: -; ALL-NEXT: vextractf128 $1, %ymm0, %xmm1 -; ALL-NEXT: vshufps {{.*}} # xmm1 = xmm1[2,0],xmm0[0,0] -; ALL-NEXT: vshufps {{.*}} # xmm1 = xmm1[2,0],xmm0[0,0] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,0,0] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_06000000 +; AVX1: # BB#0: +; AVX1-NEXT: vextractf128 $1, %ymm0, %xmm1 +; AVX1-NEXT: vshufps {{.*}} # xmm1 = xmm1[2,0],xmm0[0,0] +; AVX1-NEXT: vshufps {{.*}} # xmm1 = xmm1[2,0],xmm0[0,0] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,0,0] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_06000000 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI61_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_70000000(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_70000000 -; ALL: # BB#0: -; ALL-NEXT: vextractf128 $1, %ymm0, %xmm1 -; ALL-NEXT: vshufps {{.*}} # xmm1 = xmm1[3,0],xmm0[0,0] -; ALL-NEXT: vshufps {{.*}} # xmm1 = xmm1[0,2],xmm0[0,0] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,0,0] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_70000000 +; AVX1: # BB#0: +; AVX1-NEXT: vextractf128 $1, %ymm0, %xmm1 +; AVX1-NEXT: vshufps {{.*}} # xmm1 = xmm1[3,0],xmm0[0,0] +; AVX1-NEXT: vshufps {{.*}} # xmm1 = xmm1[0,2],xmm0[0,0] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,0,0,0] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_70000000 +; AVX2: # BB#0: +; AVX2-NEXT: vpxor %xmm1, %xmm1, %xmm1 +; AVX2-NEXT: movl $7, %eax +; AVX2-NEXT: vpinsrd $0, %eax, %xmm1, %xmm1 +; AVX2-NEXT: vpxor %ymm2, %ymm2, %ymm2 +; AVX2-NEXT: vinserti128 $0, %xmm1, %ymm2, %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } @@ -659,443 +711,720 @@ define <8 x i32> @shuffle_v8i32_01014545(<8 x i32> %a, <8 x i32> %b) { } define <8 x i32> @shuffle_v8i32_00112233(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00112233 -; ALL: # BB#0: -; ALL-NEXT: vunpcklps {{.*}} # xmm1 = xmm0[0,0,1,1] -; ALL-NEXT: vunpckhps {{.*}} # xmm0 = xmm0[2,2,3,3] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00112233 +; AVX1: # BB#0: +; AVX1-NEXT: vunpcklps {{.*}} # xmm1 = xmm0[0,0,1,1] +; AVX1-NEXT: vunpckhps {{.*}} # xmm0 = xmm0[2,2,3,3] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00112233 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI64_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00001111(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00001111 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # xmm1 = xmm0[0,0,0,0] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[1,1,1,1] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00001111 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # xmm1 = xmm0[0,0,0,0] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[1,1,1,1] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm1, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00001111 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI65_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_81a3c5e7(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_81a3c5e7 -; ALL: # BB#0: -; ALL-NEXT: vblendps {{.*}} # ymm0 = ymm1[0],ymm0[1],ymm1[2],ymm0[3],ymm1[4],ymm0[5],ymm1[6],ymm0[7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_81a3c5e7 +; AVX1: # BB#0: +; AVX1-NEXT: vblendps {{.*}} # ymm0 = ymm1[0],ymm0[1],ymm1[2],ymm0[3],ymm1[4],ymm0[5],ymm1[6],ymm0[7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_81a3c5e7 +; AVX2: # BB#0: +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm1[0],ymm0[1],ymm1[2],ymm0[3],ymm1[4],ymm0[5],ymm1[6],ymm0[7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_08080808(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_08080808 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # xmm1 = xmm1[0,0,2,0] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,1,0,3] -; ALL-NEXT: vblendps {{.*}} # xmm0 = xmm0[0],xmm1[1],xmm0[2],xmm1[3] -; ALL-NEXT: vinsertf128 $1, %xmm0, %ymm0, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_08080808 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # xmm1 = xmm1[0,0,2,0] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,1,0,3] +; AVX1-NEXT: vblendps {{.*}} # xmm0 = xmm0[0],xmm1[1],xmm0[2],xmm1[3] +; AVX1-NEXT: vinsertf128 $1, %xmm0, %ymm0, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_08080808 +; AVX2: # BB#0: +; AVX2-NEXT: vpxor %ymm2, %ymm2, %ymm2 +; AVX2-NEXT: vpermd %ymm1, %ymm2, %ymm1 +; AVX2-NEXT: vpermq {{.*}} # ymm0 = ymm0[0,0,0,0] +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm0[0],ymm1[1],ymm0[2],ymm1[3],ymm0[4],ymm1[5],ymm0[6],ymm1[7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_08084c4c(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_08084c4c -; ALL: # BB#0: -; ALL-NEXT: vshufps {{.*}} # ymm0 = ymm0[0,0],ymm1[0,0],ymm0[4,4],ymm1[4,4] -; ALL-NEXT: vshufps {{.*}} # ymm0 = ymm0[0,2,1,3,4,6,5,7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_08084c4c +; AVX1: # BB#0: +; AVX1-NEXT: vshufps {{.*}} # ymm0 = ymm0[0,0],ymm1[0,0],ymm0[4,4],ymm1[4,4] +; AVX1-NEXT: vshufps {{.*}} # ymm0 = ymm0[0,2,1,3,4,6,5,7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_08084c4c +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm1 = ymm1[0,0,2,0,4,4,6,4] +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[0,1,0,1,4,5,4,5] +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm0[0],ymm1[1],ymm0[2],ymm1[3],ymm0[4],ymm1[5],ymm0[6],ymm1[7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_8823cc67(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_8823cc67 -; ALL: # BB#0: -; ALL-NEXT: vshufps {{.*}} # ymm0 = ymm1[0,0],ymm0[2,3],ymm1[4,4],ymm0[6,7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_8823cc67 +; AVX1: # BB#0: +; AVX1-NEXT: vshufps {{.*}} # ymm0 = ymm1[0,0],ymm0[2,3],ymm1[4,4],ymm0[6,7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_8823cc67 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm1 = ymm1[0,0,2,3,4,4,6,7] +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm1[0,1],ymm0[2,3],ymm1[4,5],ymm0[6,7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_9832dc76(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_9832dc76 -; ALL: # BB#0: -; ALL-NEXT: vshufps {{.*}} # ymm0 = ymm1[1,0],ymm0[3,2],ymm1[5,4],ymm0[7,6] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_9832dc76 +; AVX1: # BB#0: +; AVX1-NEXT: vshufps {{.*}} # ymm0 = ymm1[1,0],ymm0[3,2],ymm1[5,4],ymm0[7,6] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_9832dc76 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[0,1,3,2,4,5,7,6] +; AVX2-NEXT: vpshufd {{.*}} # ymm1 = ymm1[1,0,2,3,5,4,6,7] +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm1[0,1],ymm0[2,3],ymm1[4,5],ymm0[6,7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_9810dc54(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_9810dc54 -; ALL: # BB#0: -; ALL-NEXT: vshufps {{.*}} # ymm0 = ymm1[1,0],ymm0[1,0],ymm1[5,4],ymm0[5,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_9810dc54 +; AVX1: # BB#0: +; AVX1-NEXT: vshufps {{.*}} # ymm0 = ymm1[1,0],ymm0[1,0],ymm1[5,4],ymm0[5,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_9810dc54 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[0,1,1,0,4,5,5,4] +; AVX2-NEXT: vpshufd {{.*}} # ymm1 = ymm1[1,0,2,3,5,4,6,7] +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm1[0,1],ymm0[2,3],ymm1[4,5],ymm0[6,7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_08194c5d(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_08194c5d -; ALL: # BB#0: -; ALL-NEXT: vunpcklps {{.*}} # ymm0 = ymm0[0],ymm1[0],ymm0[1],ymm1[1],ymm0[4],ymm1[4],ymm0[5],ymm1[5] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_08194c5d +; AVX1: # BB#0: +; AVX1-NEXT: vunpcklps {{.*}} # ymm0 = ymm0[0],ymm1[0],ymm0[1],ymm1[1],ymm0[4],ymm1[4],ymm0[5],ymm1[5] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_08194c5d +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm1 = ymm1[0,0,2,1,4,4,6,5] +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[0,1,1,3,4,5,5,7] +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm0[0],ymm1[1],ymm0[2],ymm1[3],ymm0[4],ymm1[5],ymm0[6],ymm1[7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_2a3b6e7f(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_2a3b6e7f -; ALL: # BB#0: -; ALL-NEXT: vunpckhps {{.*}} # ymm0 = ymm0[2],ymm1[2],ymm0[3],ymm1[3],ymm0[6],ymm1[6],ymm0[7],ymm1[7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_2a3b6e7f +; AVX1: # BB#0: +; AVX1-NEXT: vunpckhps {{.*}} # ymm0 = ymm0[2],ymm1[2],ymm0[3],ymm1[3],ymm0[6],ymm1[6],ymm0[7],ymm1[7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_2a3b6e7f +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm1 = ymm1[0,2,2,3,4,6,6,7] +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[2,1,3,3,6,5,7,7] +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm0[0],ymm1[1],ymm0[2],ymm1[3],ymm0[4],ymm1[5],ymm0[6],ymm1[7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_08192a3b(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_08192a3b -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # xmm2 = xmm1[0,2,2,3] -; ALL-NEXT: vpermilps {{.*}} # xmm3 = xmm0[2,1,3,3] -; ALL-NEXT: vblendps {{.*}} # xmm2 = xmm3[0],xmm2[1],xmm3[2],xmm2[3] -; ALL-NEXT: vpermilps {{.*}} # xmm1 = xmm1[0,0,2,1] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,1,1,3] -; ALL-NEXT: vblendps {{.*}} # xmm0 = xmm0[0],xmm1[1],xmm0[2],xmm1[3] -; ALL-NEXT: vinsertf128 $1, %xmm2, %ymm0, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_08192a3b +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # xmm2 = xmm1[0,2,2,3] +; AVX1-NEXT: vpermilps {{.*}} # xmm3 = xmm0[2,1,3,3] +; AVX1-NEXT: vblendps {{.*}} # xmm2 = xmm3[0],xmm2[1],xmm3[2],xmm2[3] +; AVX1-NEXT: vpermilps {{.*}} # xmm1 = xmm1[0,0,2,1] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,1,1,3] +; AVX1-NEXT: vblendps {{.*}} # xmm0 = xmm0[0],xmm1[1],xmm0[2],xmm1[3] +; AVX1-NEXT: vinsertf128 $1, %xmm2, %ymm0, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_08192a3b +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI74_0(%rip), %ymm2 +; AVX2-NEXT: vpermd %ymm1, %ymm2, %ymm1 +; AVX2-NEXT: vmovdqa .LCPI74_1(%rip), %ymm2 +; AVX2-NEXT: vpermd %ymm0, %ymm2, %ymm0 +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm0[0],ymm1[1],ymm0[2],ymm1[3],ymm0[4],ymm1[5],ymm0[6],ymm1[7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_08991abb(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_08991abb -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # xmm2 = xmm0[1,1,2,3] -; ALL-NEXT: vpermilps {{.*}} # xmm3 = xmm1[0,2,3,3] -; ALL-NEXT: vblendps {{.*}} # xmm2 = xmm2[0],xmm3[1,2,3] -; ALL-NEXT: vunpcklps {{.*}} # xmm1 = xmm1[0,0,1,1] -; ALL-NEXT: vblendps {{.*}} # xmm0 = xmm0[0],xmm1[1,2,3] -; ALL-NEXT: vinsertf128 $1, %xmm2, %ymm0, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_08991abb +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # xmm2 = xmm0[1,1,2,3] +; AVX1-NEXT: vpermilps {{.*}} # xmm3 = xmm1[0,2,3,3] +; AVX1-NEXT: vblendps {{.*}} # xmm2 = xmm2[0],xmm3[1,2,3] +; AVX1-NEXT: vunpcklps {{.*}} # xmm1 = xmm1[0,0,1,1] +; AVX1-NEXT: vblendps {{.*}} # xmm0 = xmm0[0],xmm1[1,2,3] +; AVX1-NEXT: vinsertf128 $1, %xmm2, %ymm0, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_08991abb +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI75_0(%rip), %ymm2 +; AVX2-NEXT: vpermd %ymm0, %ymm2, %ymm0 +; AVX2-NEXT: vmovdqa .LCPI75_1(%rip), %ymm2 +; AVX2-NEXT: vpermd %ymm1, %ymm2, %ymm1 +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm0[0],ymm1[1,2,3],ymm0[4],ymm1[5,6,7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_091b2d3f(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_091b2d3f -; ALL: # BB#0: -; ALL-NEXT: vextractf128 $1, %ymm1, %xmm2 -; ALL-NEXT: vpermilps {{.*}} # xmm3 = xmm0[2,1,3,3] -; ALL-NEXT: vblendps {{.*}} # xmm2 = xmm3[0],xmm2[1],xmm3[2],xmm2[3] -; ALL-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,1,1,3] -; ALL-NEXT: vblendps {{.*}} # xmm0 = xmm0[0],xmm1[1],xmm0[2],xmm1[3] -; ALL-NEXT: vinsertf128 $1, %xmm2, %ymm0, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_091b2d3f +; AVX1: # BB#0: +; AVX1-NEXT: vextractf128 $1, %ymm1, %xmm2 +; AVX1-NEXT: vpermilps {{.*}} # xmm3 = xmm0[2,1,3,3] +; AVX1-NEXT: vblendps {{.*}} # xmm2 = xmm3[0],xmm2[1],xmm3[2],xmm2[3] +; AVX1-NEXT: vpermilps {{.*}} # xmm0 = xmm0[0,1,1,3] +; AVX1-NEXT: vblendps {{.*}} # xmm0 = xmm0[0],xmm1[1],xmm0[2],xmm1[3] +; AVX1-NEXT: vinsertf128 $1, %xmm2, %ymm0, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_091b2d3f +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI76_0(%rip), %ymm2 +; AVX2-NEXT: vpermd %ymm0, %ymm2, %ymm0 +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm0[0],ymm1[1],ymm0[2],ymm1[3],ymm0[4],ymm1[5],ymm0[6],ymm1[7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_09ab1def(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_09ab1def -; ALL: # BB#0: -; ALL-NEXT: vextractf128 $1, %ymm1, %xmm2 -; ALL-NEXT: vpermilps {{.*}} # xmm3 = xmm0[1,1,2,3] -; ALL-NEXT: vblendps {{.*}} # xmm2 = xmm3[0],xmm2[1,2,3] -; ALL-NEXT: vblendps {{.*}} # xmm0 = xmm0[0],xmm1[1,2,3] -; ALL-NEXT: vinsertf128 $1, %xmm2, %ymm0, %ymm0 -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_09ab1def +; AVX1: # BB#0: +; AVX1-NEXT: vextractf128 $1, %ymm1, %xmm2 +; AVX1-NEXT: vpermilps {{.*}} # xmm3 = xmm0[1,1,2,3] +; AVX1-NEXT: vblendps {{.*}} # xmm2 = xmm3[0],xmm2[1,2,3] +; AVX1-NEXT: vblendps {{.*}} # xmm0 = xmm0[0],xmm1[1,2,3] +; AVX1-NEXT: vinsertf128 $1, %xmm2, %ymm0, %ymm0 +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_09ab1def +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI77_0(%rip), %ymm2 +; AVX2-NEXT: vpermd %ymm0, %ymm2, %ymm0 +; AVX2-NEXT: vpblendd {{.*}} # ymm0 = ymm0[0],ymm1[1,2,3],ymm0[4],ymm1[5,6,7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00014445(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00014445 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,0,1,4,4,4,5] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00014445 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,0,1,4,4,4,5] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00014445 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[0,0,0,1,4,4,4,5] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00204464(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00204464 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,0,4,4,6,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00204464 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,0,4,4,6,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00204464 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[0,0,2,0,4,4,6,4] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_03004744(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_03004744 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,3,0,0,4,7,4,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_03004744 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,3,0,0,4,7,4,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_03004744 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[0,3,0,0,4,7,4,4] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_10005444(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_10005444 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,0,0,5,4,4,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_10005444 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,0,0,5,4,4,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_10005444 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[1,0,0,0,5,4,4,4] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_22006644(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_22006644 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[2,2,0,0,6,6,4,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_22006644 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[2,2,0,0,6,6,4,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_22006644 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[2,2,0,0,6,6,4,4] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_33307774(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_33307774 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[3,3,3,0,7,7,7,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_33307774 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[3,3,3,0,7,7,7,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_33307774 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[3,3,3,0,7,7,7,4] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_32107654(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_32107654 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[3,2,1,0,7,6,5,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_32107654 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[3,2,1,0,7,6,5,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_32107654 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[3,2,1,0,7,6,5,4] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00234467(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00234467 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,3,4,4,6,7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00234467 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,3,4,4,6,7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00234467 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[0,0,2,3,4,4,6,7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00224466(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00224466 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,2,4,4,6,6] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00224466 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,2,4,4,6,6] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00224466 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[0,0,2,2,4,4,6,6] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_10325476(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_10325476 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,3,2,5,4,7,6] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_10325476 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,3,2,5,4,7,6] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_10325476 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[1,0,3,2,5,4,7,6] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_11335577(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_11335577 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,1,3,3,5,5,7,7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_11335577 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,1,3,3,5,5,7,7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_11335577 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[1,1,3,3,5,5,7,7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_10235467(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_10235467 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,2,3,5,4,6,7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_10235467 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,2,3,5,4,6,7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_10235467 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[1,0,2,3,5,4,6,7] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_10225466(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_10225466 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,2,2,5,4,6,6] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_10225466 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,2,2,5,4,6,6] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_10225466 +; AVX2: # BB#0: +; AVX2-NEXT: vpshufd {{.*}} # ymm0 = ymm0[1,0,2,2,5,4,6,6] +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00015444(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00015444 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,0,1,5,4,4,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00015444 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,0,1,5,4,4,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00015444 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI91_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00204644(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00204644 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,0,4,6,4,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00204644 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,0,4,6,4,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00204644 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI92_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_03004474(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_03004474 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,3,0,0,4,4,7,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_03004474 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,3,0,0,4,4,7,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_03004474 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI93_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_10004444(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_10004444 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,0,0,4,4,4,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_10004444 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,0,0,4,4,4,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_10004444 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI94_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_22006446(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_22006446 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[2,2,0,0,6,4,4,6] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_22006446 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[2,2,0,0,6,4,4,6] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_22006446 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI95_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_33307474(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_33307474 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[3,3,3,0,7,4,7,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_33307474 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[3,3,3,0,7,4,7,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_33307474 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI96_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_32104567(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_32104567 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[3,2,1,0,4,5,6,7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_32104567 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[3,2,1,0,4,5,6,7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_32104567 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI97_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00236744(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00236744 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,3,6,7,4,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00236744 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,3,6,7,4,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00236744 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI98_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00226644(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00226644 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,2,6,6,4,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00226644 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,2,6,6,4,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00226644 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI99_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_10324567(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_10324567 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,3,2,4,5,6,7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_10324567 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,3,2,4,5,6,7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_10324567 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI100_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_11334567(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_11334567 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,1,3,3,4,5,6,7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_11334567 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,1,3,3,4,5,6,7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_11334567 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI101_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_01235467(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_01235467 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,1,2,3,5,4,6,7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_01235467 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,1,2,3,5,4,6,7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_01235467 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI102_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_01235466(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_01235466 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,1,2,3,5,4,6,6] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_01235466 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,1,2,3,5,4,6,6] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_01235466 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI103_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_002u6u44(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_002u6u44 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,u,6,u,4,4] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_002u6u44 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,2,u,6,u,4,4] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_002u6u44 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI104_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_00uu66uu(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_00uu66uu -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,u,u,6,6,u,u] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_00uu66uu +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,0,u,u,6,6,u,u] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_00uu66uu +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI105_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_103245uu(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_103245uu -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,3,2,4,5,u,u] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_103245uu +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,0,3,2,4,5,u,u] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_103245uu +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI106_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_1133uu67(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_1133uu67 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,1,3,3,u,u,6,7] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_1133uu67 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[1,1,3,3,u,u,6,7] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_1133uu67 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI107_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_0uu354uu(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_0uu354uu -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,u,u,3,5,4,u,u] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_0uu354uu +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[0,u,u,3,5,4,u,u] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_0uu354uu +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI108_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle } define <8 x i32> @shuffle_v8i32_uuu3uu66(<8 x i32> %a, <8 x i32> %b) { -; ALL-LABEL: @shuffle_v8i32_uuu3uu66 -; ALL: # BB#0: -; ALL-NEXT: vpermilps {{.*}} # ymm0 = ymm0[u,u,u,3,u,u,6,6] -; ALL-NEXT: retq +; AVX1-LABEL: @shuffle_v8i32_uuu3uu66 +; AVX1: # BB#0: +; AVX1-NEXT: vpermilps {{.*}} # ymm0 = ymm0[u,u,u,3,u,u,6,6] +; AVX1-NEXT: retq +; +; AVX2-LABEL: @shuffle_v8i32_uuu3uu66 +; AVX2: # BB#0: +; AVX2-NEXT: vmovdqa .LCPI109_0(%rip), %ymm1 +; AVX2-NEXT: vpermd %ymm0, %ymm1, %ymm0 +; AVX2-NEXT: retq %shuffle = shufflevector <8 x i32> %a, <8 x i32> %b, <8 x i32> ret <8 x i32> %shuffle }