; SSE2-NEXT: # kill: def $edx killed $edx def $rdx
; SSE2-NEXT: # kill: def $esi killed $esi def $rsi
; SSE2-NEXT: # kill: def $edi killed $edi def $rdi
+; SSE2-NEXT: movzwl {{[0-9]+}}(%rsp), %r10d
+; SSE2-NEXT: andl $7, %r10d
+; SSE2-NEXT: movzwl {{[0-9]+}}(%rsp), %eax
+; SSE2-NEXT: andl $7, %eax
; SSE2-NEXT: andl $7, %edi
; SSE2-NEXT: andl $7, %esi
; SSE2-NEXT: andl $7, %edx
; SSE2-NEXT: andl $7, %r8d
; SSE2-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSE2-NEXT: andl $7, %r9d
-; SSE2-NEXT: movzwl {{[0-9]+}}(%rsp), %r10d
-; SSE2-NEXT: andl $7, %r10d
-; SSE2-NEXT: movzwl {{[0-9]+}}(%rsp), %eax
-; SSE2-NEXT: andl $7, %eax
; SSE2-NEXT: movzwl -24(%rsp,%rcx,2), %ecx
; SSE2-NEXT: movd %ecx, %xmm0
; SSE2-NEXT: movzwl -24(%rsp,%rdx,2), %ecx
; SSSE3-NEXT: # kill: def $edx killed $edx def $rdx
; SSSE3-NEXT: # kill: def $esi killed $esi def $rsi
; SSSE3-NEXT: # kill: def $edi killed $edi def $rdi
+; SSSE3-NEXT: movzwl {{[0-9]+}}(%rsp), %r10d
+; SSSE3-NEXT: andl $7, %r10d
+; SSSE3-NEXT: movzwl {{[0-9]+}}(%rsp), %eax
+; SSSE3-NEXT: andl $7, %eax
; SSSE3-NEXT: andl $7, %edi
; SSSE3-NEXT: andl $7, %esi
; SSSE3-NEXT: andl $7, %edx
; SSSE3-NEXT: andl $7, %r8d
; SSSE3-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSSE3-NEXT: andl $7, %r9d
-; SSSE3-NEXT: movzwl {{[0-9]+}}(%rsp), %r10d
-; SSSE3-NEXT: andl $7, %r10d
-; SSSE3-NEXT: movzwl {{[0-9]+}}(%rsp), %eax
-; SSSE3-NEXT: andl $7, %eax
; SSSE3-NEXT: movzwl -24(%rsp,%rcx,2), %ecx
; SSSE3-NEXT: movd %ecx, %xmm0
; SSSE3-NEXT: movzwl -24(%rsp,%rdx,2), %ecx
; SSE41-NEXT: # kill: def $edx killed $edx def $rdx
; SSE41-NEXT: # kill: def $esi killed $esi def $rsi
; SSE41-NEXT: # kill: def $edi killed $edi def $rdi
+; SSE41-NEXT: movzwl {{[0-9]+}}(%rsp), %r10d
+; SSE41-NEXT: andl $7, %r10d
+; SSE41-NEXT: movzwl {{[0-9]+}}(%rsp), %eax
+; SSE41-NEXT: andl $7, %eax
; SSE41-NEXT: andl $7, %edi
; SSE41-NEXT: andl $7, %esi
; SSE41-NEXT: andl $7, %edx
; SSE41-NEXT: andl $7, %r8d
; SSE41-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSE41-NEXT: andl $7, %r9d
-; SSE41-NEXT: movzwl {{[0-9]+}}(%rsp), %r10d
-; SSE41-NEXT: andl $7, %r10d
-; SSE41-NEXT: movzwl {{[0-9]+}}(%rsp), %eax
-; SSE41-NEXT: andl $7, %eax
; SSE41-NEXT: movzwl -24(%rsp,%rdi,2), %edi
; SSE41-NEXT: movd %edi, %xmm0
; SSE41-NEXT: pinsrw $1, -24(%rsp,%rsi,2), %xmm0
; SSE41-NEXT: pinsrw $3, -24(%rsp,%rcx,2), %xmm0
; SSE41-NEXT: pinsrw $4, -24(%rsp,%r8,2), %xmm0
; SSE41-NEXT: pinsrw $5, -24(%rsp,%r9,2), %xmm0
-; SSE41-NEXT: pinsrw $6, -24(%rsp,%r10,2), %xmm0
-; SSE41-NEXT: pinsrw $7, -24(%rsp,%rax,2), %xmm0
+; SSE41-NEXT: pinsrw $6, -24(%rsp,%rax,2), %xmm0
+; SSE41-NEXT: pinsrw $7, -24(%rsp,%r10,2), %xmm0
; SSE41-NEXT: retq
;
; AVX-LABEL: var_shuffle_v8i16_v8i16_xxxxxxxx_i16:
; AVX-NEXT: # kill: def $edx killed $edx def $rdx
; AVX-NEXT: # kill: def $esi killed $esi def $rsi
; AVX-NEXT: # kill: def $edi killed $edi def $rdi
+; AVX-NEXT: movzwl {{[0-9]+}}(%rsp), %r10d
+; AVX-NEXT: andl $7, %r10d
+; AVX-NEXT: movzwl {{[0-9]+}}(%rsp), %eax
+; AVX-NEXT: andl $7, %eax
; AVX-NEXT: andl $7, %edi
; AVX-NEXT: andl $7, %esi
; AVX-NEXT: andl $7, %edx
; AVX-NEXT: andl $7, %r8d
; AVX-NEXT: vmovaps %xmm0, -{{[0-9]+}}(%rsp)
; AVX-NEXT: andl $7, %r9d
-; AVX-NEXT: movzwl {{[0-9]+}}(%rsp), %r10d
-; AVX-NEXT: andl $7, %r10d
-; AVX-NEXT: movzwl {{[0-9]+}}(%rsp), %eax
-; AVX-NEXT: andl $7, %eax
; AVX-NEXT: movzwl -24(%rsp,%rdi,2), %edi
; AVX-NEXT: vmovd %edi, %xmm0
; AVX-NEXT: vpinsrw $1, -24(%rsp,%rsi,2), %xmm0, %xmm0
; AVX-NEXT: vpinsrw $3, -24(%rsp,%rcx,2), %xmm0, %xmm0
; AVX-NEXT: vpinsrw $4, -24(%rsp,%r8,2), %xmm0, %xmm0
; AVX-NEXT: vpinsrw $5, -24(%rsp,%r9,2), %xmm0, %xmm0
-; AVX-NEXT: vpinsrw $6, -24(%rsp,%r10,2), %xmm0, %xmm0
-; AVX-NEXT: vpinsrw $7, -24(%rsp,%rax,2), %xmm0, %xmm0
+; AVX-NEXT: vpinsrw $6, -24(%rsp,%rax,2), %xmm0, %xmm0
+; AVX-NEXT: vpinsrw $7, -24(%rsp,%r10,2), %xmm0, %xmm0
; AVX-NEXT: retq
%x0 = extractelement <8 x i16> %x, i16 %i0
%x1 = extractelement <8 x i16> %x, i16 %i1
; SSE2-NEXT: # kill: def $edx killed $edx def $rdx
; SSE2-NEXT: # kill: def $esi killed $esi def $rsi
; SSE2-NEXT: # kill: def $edi killed $edi def $rdi
-; SSE2-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSE2-NEXT: movzbl {{[0-9]+}}(%rsp), %eax
; SSE2-NEXT: andl $15, %eax
+; SSE2-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSE2-NEXT: movzbl -24(%rsp,%rax), %eax
; SSE2-NEXT: movd %eax, %xmm8
; SSE2-NEXT: movzbl {{[0-9]+}}(%rsp), %eax
; SSSE3-NEXT: # kill: def $edx killed $edx def $rdx
; SSSE3-NEXT: # kill: def $esi killed $esi def $rsi
; SSSE3-NEXT: # kill: def $edi killed $edi def $rdi
-; SSSE3-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSSE3-NEXT: movzbl {{[0-9]+}}(%rsp), %eax
; SSSE3-NEXT: andl $15, %eax
+; SSSE3-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSSE3-NEXT: movzbl -24(%rsp,%rax), %eax
; SSSE3-NEXT: movd %eax, %xmm8
; SSSE3-NEXT: movzbl {{[0-9]+}}(%rsp), %eax
; SSE2-NEXT: movl (%rdi), %eax
; SSE2-NEXT: movl 4(%rdi), %ecx
; SSE2-NEXT: andl $3, %eax
-; SSE2-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSE2-NEXT: andl $3, %ecx
; SSE2-NEXT: movl 8(%rdi), %edx
; SSE2-NEXT: andl $3, %edx
; SSE2-NEXT: movl 12(%rdi), %esi
; SSE2-NEXT: andl $3, %esi
+; SSE2-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSE2-NEXT: movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
; SSE2-NEXT: movss {{.*#+}} xmm1 = mem[0],zero,zero,zero
; SSE2-NEXT: unpcklps {{.*#+}} xmm1 = xmm1[0],xmm0[0],xmm1[1],xmm0[1]
; SSSE3-NEXT: movl (%rdi), %eax
; SSSE3-NEXT: movl 4(%rdi), %ecx
; SSSE3-NEXT: andl $3, %eax
-; SSSE3-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSSE3-NEXT: andl $3, %ecx
; SSSE3-NEXT: movl 8(%rdi), %edx
; SSSE3-NEXT: andl $3, %edx
; SSSE3-NEXT: movl 12(%rdi), %esi
; SSSE3-NEXT: andl $3, %esi
+; SSSE3-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSSE3-NEXT: movss {{.*#+}} xmm0 = mem[0],zero,zero,zero
; SSSE3-NEXT: movss {{.*#+}} xmm1 = mem[0],zero,zero,zero
; SSSE3-NEXT: unpcklps {{.*#+}} xmm1 = xmm1[0],xmm0[0],xmm1[1],xmm0[1]
; SSE41-NEXT: movl (%rdi), %eax
; SSE41-NEXT: movl 4(%rdi), %ecx
; SSE41-NEXT: andl $3, %eax
-; SSE41-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSE41-NEXT: andl $3, %ecx
; SSE41-NEXT: movl 8(%rdi), %edx
; SSE41-NEXT: andl $3, %edx
; SSE41-NEXT: movl 12(%rdi), %esi
; SSE41-NEXT: andl $3, %esi
+; SSE41-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
; SSE41-NEXT: movd {{.*#+}} xmm0 = mem[0],zero,zero,zero
; SSE41-NEXT: pinsrd $1, -24(%rsp,%rcx,4), %xmm0
; SSE41-NEXT: pinsrd $2, -24(%rsp,%rdx,4), %xmm0
; AVX-NEXT: movl (%rdi), %eax
; AVX-NEXT: movl 4(%rdi), %ecx
; AVX-NEXT: andl $3, %eax
-; AVX-NEXT: vmovaps %xmm0, -{{[0-9]+}}(%rsp)
; AVX-NEXT: andl $3, %ecx
; AVX-NEXT: movl 8(%rdi), %edx
; AVX-NEXT: andl $3, %edx
; AVX-NEXT: movl 12(%rdi), %esi
; AVX-NEXT: andl $3, %esi
+; AVX-NEXT: vmovaps %xmm0, -{{[0-9]+}}(%rsp)
; AVX-NEXT: vmovd {{.*#+}} xmm0 = mem[0],zero,zero,zero
; AVX-NEXT: vpinsrd $1, -24(%rsp,%rcx,4), %xmm0, %xmm0
; AVX-NEXT: vpinsrd $2, -24(%rsp,%rdx,4), %xmm0, %xmm0
define <16 x i8> @mem_shuffle_v16i8_v16i8_xxxxxxxxxxxxxxxx_i8(<16 x i8> %x, i8* %i) nounwind {
; SSE2-LABEL: mem_shuffle_v16i8_v16i8_xxxxxxxxxxxxxxxx_i8:
; SSE2: # %bb.0:
+; SSE2-NEXT: pushq %rbp
+; SSE2-NEXT: pushq %r15
+; SSE2-NEXT: pushq %r14
+; SSE2-NEXT: pushq %r13
+; SSE2-NEXT: pushq %r12
+; SSE2-NEXT: pushq %rbx
; SSE2-NEXT: movzbl (%rdi), %eax
-; SSE2-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
-; SSE2-NEXT: movzbl 15(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm8
-; SSE2-NEXT: movzbl 14(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm15
-; SSE2-NEXT: movzbl 13(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm9
-; SSE2-NEXT: movzbl 12(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm3
-; SSE2-NEXT: movzbl 11(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm10
+; SSE2-NEXT: movq %rax, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill
+; SSE2-NEXT: movzbl 1(%rdi), %r9d
+; SSE2-NEXT: movzbl 2(%rdi), %r10d
+; SSE2-NEXT: movzbl 3(%rdi), %r11d
+; SSE2-NEXT: movzbl 4(%rdi), %r14d
+; SSE2-NEXT: movzbl 5(%rdi), %r15d
+; SSE2-NEXT: movzbl 6(%rdi), %r12d
+; SSE2-NEXT: movzbl 7(%rdi), %r13d
+; SSE2-NEXT: movzbl 8(%rdi), %ebx
+; SSE2-NEXT: movzbl 9(%rdi), %r8d
; SSE2-NEXT: movzbl 10(%rdi), %ecx
+; SSE2-NEXT: movzbl 11(%rdi), %edx
+; SSE2-NEXT: movzbl 12(%rdi), %esi
+; SSE2-NEXT: movzbl 13(%rdi), %ebp
+; SSE2-NEXT: movzbl 14(%rdi), %eax
+; SSE2-NEXT: movzbl 15(%rdi), %edi
+; SSE2-NEXT: andl $15, %edi
+; SSE2-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
+; SSE2-NEXT: movzbl -24(%rsp,%rdi), %edi
+; SSE2-NEXT: movd %edi, %xmm8
+; SSE2-NEXT: andl $15, %eax
+; SSE2-NEXT: movzbl -24(%rsp,%rax), %eax
+; SSE2-NEXT: movd %eax, %xmm15
+; SSE2-NEXT: andl $15, %ebp
+; SSE2-NEXT: movzbl -24(%rsp,%rbp), %eax
+; SSE2-NEXT: movd %eax, %xmm9
+; SSE2-NEXT: andl $15, %esi
+; SSE2-NEXT: movzbl -24(%rsp,%rsi), %eax
+; SSE2-NEXT: movd %eax, %xmm3
+; SSE2-NEXT: andl $15, %edx
+; SSE2-NEXT: movzbl -24(%rsp,%rdx), %eax
+; SSE2-NEXT: movd %eax, %xmm10
; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm7
-; SSE2-NEXT: movzbl 9(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm11
-; SSE2-NEXT: movzbl 8(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm6
-; SSE2-NEXT: movzbl 7(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm12
-; SSE2-NEXT: movzbl 6(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm5
-; SSE2-NEXT: movzbl 5(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm13
-; SSE2-NEXT: movzbl 4(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm4
-; SSE2-NEXT: movzbl 3(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm14
-; SSE2-NEXT: movzbl 2(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm1
-; SSE2-NEXT: movzbl 1(%rdi), %ecx
-; SSE2-NEXT: andl $15, %ecx
-; SSE2-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSE2-NEXT: movd %ecx, %xmm2
+; SSE2-NEXT: movzbl -24(%rsp,%rcx), %eax
+; SSE2-NEXT: movd %eax, %xmm7
+; SSE2-NEXT: andl $15, %r8d
+; SSE2-NEXT: movzbl -24(%rsp,%r8), %eax
+; SSE2-NEXT: movd %eax, %xmm11
+; SSE2-NEXT: andl $15, %ebx
+; SSE2-NEXT: movzbl -24(%rsp,%rbx), %eax
+; SSE2-NEXT: movd %eax, %xmm6
+; SSE2-NEXT: andl $15, %r13d
+; SSE2-NEXT: movzbl -24(%rsp,%r13), %eax
+; SSE2-NEXT: movd %eax, %xmm12
+; SSE2-NEXT: andl $15, %r12d
+; SSE2-NEXT: movzbl -24(%rsp,%r12), %eax
+; SSE2-NEXT: movd %eax, %xmm5
+; SSE2-NEXT: andl $15, %r15d
+; SSE2-NEXT: movzbl -24(%rsp,%r15), %eax
+; SSE2-NEXT: movd %eax, %xmm13
+; SSE2-NEXT: andl $15, %r14d
+; SSE2-NEXT: movzbl -24(%rsp,%r14), %eax
+; SSE2-NEXT: movd %eax, %xmm4
+; SSE2-NEXT: andl $15, %r11d
+; SSE2-NEXT: movzbl -24(%rsp,%r11), %eax
+; SSE2-NEXT: movd %eax, %xmm14
+; SSE2-NEXT: andl $15, %r10d
+; SSE2-NEXT: movzbl -24(%rsp,%r10), %eax
+; SSE2-NEXT: movd %eax, %xmm1
+; SSE2-NEXT: andl $15, %r9d
+; SSE2-NEXT: movzbl -24(%rsp,%r9), %eax
+; SSE2-NEXT: movd %eax, %xmm2
+; SSE2-NEXT: movq {{[-0-9]+}}(%r{{[sb]}}p), %rax # 8-byte Reload
; SSE2-NEXT: andl $15, %eax
; SSE2-NEXT: movzbl -24(%rsp,%rax), %eax
; SSE2-NEXT: movd %eax, %xmm0
; SSE2-NEXT: punpcklwd {{.*#+}} xmm0 = xmm0[0],xmm1[0],xmm0[1],xmm1[1],xmm0[2],xmm1[2],xmm0[3],xmm1[3]
; SSE2-NEXT: punpckldq {{.*#+}} xmm0 = xmm0[0],xmm4[0],xmm0[1],xmm4[1]
; SSE2-NEXT: punpcklqdq {{.*#+}} xmm0 = xmm0[0],xmm6[0]
+; SSE2-NEXT: popq %rbx
+; SSE2-NEXT: popq %r12
+; SSE2-NEXT: popq %r13
+; SSE2-NEXT: popq %r14
+; SSE2-NEXT: popq %r15
+; SSE2-NEXT: popq %rbp
; SSE2-NEXT: retq
;
; SSSE3-LABEL: mem_shuffle_v16i8_v16i8_xxxxxxxxxxxxxxxx_i8:
; SSSE3: # %bb.0:
+; SSSE3-NEXT: pushq %rbp
+; SSSE3-NEXT: pushq %r15
+; SSSE3-NEXT: pushq %r14
+; SSSE3-NEXT: pushq %r13
+; SSSE3-NEXT: pushq %r12
+; SSSE3-NEXT: pushq %rbx
; SSSE3-NEXT: movzbl (%rdi), %eax
-; SSSE3-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
-; SSSE3-NEXT: movzbl 15(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm8
-; SSSE3-NEXT: movzbl 14(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm15
-; SSSE3-NEXT: movzbl 13(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm9
-; SSSE3-NEXT: movzbl 12(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm3
-; SSSE3-NEXT: movzbl 11(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm10
+; SSSE3-NEXT: movq %rax, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill
+; SSSE3-NEXT: movzbl 1(%rdi), %r9d
+; SSSE3-NEXT: movzbl 2(%rdi), %r10d
+; SSSE3-NEXT: movzbl 3(%rdi), %r11d
+; SSSE3-NEXT: movzbl 4(%rdi), %r14d
+; SSSE3-NEXT: movzbl 5(%rdi), %r15d
+; SSSE3-NEXT: movzbl 6(%rdi), %r12d
+; SSSE3-NEXT: movzbl 7(%rdi), %r13d
+; SSSE3-NEXT: movzbl 8(%rdi), %ebx
+; SSSE3-NEXT: movzbl 9(%rdi), %r8d
; SSSE3-NEXT: movzbl 10(%rdi), %ecx
+; SSSE3-NEXT: movzbl 11(%rdi), %edx
+; SSSE3-NEXT: movzbl 12(%rdi), %esi
+; SSSE3-NEXT: movzbl 13(%rdi), %ebp
+; SSSE3-NEXT: movzbl 14(%rdi), %eax
+; SSSE3-NEXT: movzbl 15(%rdi), %edi
+; SSSE3-NEXT: andl $15, %edi
+; SSSE3-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
+; SSSE3-NEXT: movzbl -24(%rsp,%rdi), %edi
+; SSSE3-NEXT: movd %edi, %xmm8
+; SSSE3-NEXT: andl $15, %eax
+; SSSE3-NEXT: movzbl -24(%rsp,%rax), %eax
+; SSSE3-NEXT: movd %eax, %xmm15
+; SSSE3-NEXT: andl $15, %ebp
+; SSSE3-NEXT: movzbl -24(%rsp,%rbp), %eax
+; SSSE3-NEXT: movd %eax, %xmm9
+; SSSE3-NEXT: andl $15, %esi
+; SSSE3-NEXT: movzbl -24(%rsp,%rsi), %eax
+; SSSE3-NEXT: movd %eax, %xmm3
+; SSSE3-NEXT: andl $15, %edx
+; SSSE3-NEXT: movzbl -24(%rsp,%rdx), %eax
+; SSSE3-NEXT: movd %eax, %xmm10
; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm7
-; SSSE3-NEXT: movzbl 9(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm11
-; SSSE3-NEXT: movzbl 8(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm6
-; SSSE3-NEXT: movzbl 7(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm12
-; SSSE3-NEXT: movzbl 6(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm5
-; SSSE3-NEXT: movzbl 5(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm13
-; SSSE3-NEXT: movzbl 4(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm4
-; SSSE3-NEXT: movzbl 3(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm14
-; SSSE3-NEXT: movzbl 2(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm1
-; SSSE3-NEXT: movzbl 1(%rdi), %ecx
-; SSSE3-NEXT: andl $15, %ecx
-; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %ecx
-; SSSE3-NEXT: movd %ecx, %xmm2
+; SSSE3-NEXT: movzbl -24(%rsp,%rcx), %eax
+; SSSE3-NEXT: movd %eax, %xmm7
+; SSSE3-NEXT: andl $15, %r8d
+; SSSE3-NEXT: movzbl -24(%rsp,%r8), %eax
+; SSSE3-NEXT: movd %eax, %xmm11
+; SSSE3-NEXT: andl $15, %ebx
+; SSSE3-NEXT: movzbl -24(%rsp,%rbx), %eax
+; SSSE3-NEXT: movd %eax, %xmm6
+; SSSE3-NEXT: andl $15, %r13d
+; SSSE3-NEXT: movzbl -24(%rsp,%r13), %eax
+; SSSE3-NEXT: movd %eax, %xmm12
+; SSSE3-NEXT: andl $15, %r12d
+; SSSE3-NEXT: movzbl -24(%rsp,%r12), %eax
+; SSSE3-NEXT: movd %eax, %xmm5
+; SSSE3-NEXT: andl $15, %r15d
+; SSSE3-NEXT: movzbl -24(%rsp,%r15), %eax
+; SSSE3-NEXT: movd %eax, %xmm13
+; SSSE3-NEXT: andl $15, %r14d
+; SSSE3-NEXT: movzbl -24(%rsp,%r14), %eax
+; SSSE3-NEXT: movd %eax, %xmm4
+; SSSE3-NEXT: andl $15, %r11d
+; SSSE3-NEXT: movzbl -24(%rsp,%r11), %eax
+; SSSE3-NEXT: movd %eax, %xmm14
+; SSSE3-NEXT: andl $15, %r10d
+; SSSE3-NEXT: movzbl -24(%rsp,%r10), %eax
+; SSSE3-NEXT: movd %eax, %xmm1
+; SSSE3-NEXT: andl $15, %r9d
+; SSSE3-NEXT: movzbl -24(%rsp,%r9), %eax
+; SSSE3-NEXT: movd %eax, %xmm2
+; SSSE3-NEXT: movq {{[-0-9]+}}(%r{{[sb]}}p), %rax # 8-byte Reload
; SSSE3-NEXT: andl $15, %eax
; SSSE3-NEXT: movzbl -24(%rsp,%rax), %eax
; SSSE3-NEXT: movd %eax, %xmm0
; SSSE3-NEXT: punpcklwd {{.*#+}} xmm0 = xmm0[0],xmm1[0],xmm0[1],xmm1[1],xmm0[2],xmm1[2],xmm0[3],xmm1[3]
; SSSE3-NEXT: punpckldq {{.*#+}} xmm0 = xmm0[0],xmm4[0],xmm0[1],xmm4[1]
; SSSE3-NEXT: punpcklqdq {{.*#+}} xmm0 = xmm0[0],xmm6[0]
+; SSSE3-NEXT: popq %rbx
+; SSSE3-NEXT: popq %r12
+; SSSE3-NEXT: popq %r13
+; SSSE3-NEXT: popq %r14
+; SSSE3-NEXT: popq %r15
+; SSSE3-NEXT: popq %rbp
; SSSE3-NEXT: retq
;
; SSE41-LABEL: mem_shuffle_v16i8_v16i8_xxxxxxxxxxxxxxxx_i8:
; SSE41: # %bb.0:
-; SSE41-NEXT: movzbl (%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
-; SSE41-NEXT: movzbl -24(%rsp,%rax), %eax
-; SSE41-NEXT: movd %eax, %xmm0
-; SSE41-NEXT: movzbl 1(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $1, -24(%rsp,%rax), %xmm0
+; SSE41-NEXT: pushq %rbp
+; SSE41-NEXT: pushq %r15
+; SSE41-NEXT: pushq %r14
+; SSE41-NEXT: pushq %r13
+; SSE41-NEXT: pushq %r12
+; SSE41-NEXT: pushq %rbx
+; SSE41-NEXT: movzbl (%rdi), %r9d
+; SSE41-NEXT: andl $15, %r9d
+; SSE41-NEXT: movzbl 1(%rdi), %ebx
; SSE41-NEXT: movzbl 2(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $2, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 3(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $3, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 4(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $4, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 5(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $5, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 6(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $6, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 7(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $7, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 8(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $8, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 9(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $9, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 10(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $10, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 11(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $11, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 12(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $12, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 13(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $13, -24(%rsp,%rax), %xmm0
+; SSE41-NEXT: movq %rax, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill
+; SSE41-NEXT: movzbl 3(%rdi), %r11d
+; SSE41-NEXT: movzbl 4(%rdi), %r14d
+; SSE41-NEXT: movzbl 5(%rdi), %r15d
+; SSE41-NEXT: movzbl 6(%rdi), %r12d
+; SSE41-NEXT: movzbl 7(%rdi), %r13d
+; SSE41-NEXT: movzbl 8(%rdi), %r10d
+; SSE41-NEXT: movzbl 9(%rdi), %r8d
+; SSE41-NEXT: movzbl 10(%rdi), %ecx
+; SSE41-NEXT: movzbl 11(%rdi), %edx
+; SSE41-NEXT: movzbl 12(%rdi), %esi
+; SSE41-NEXT: movzbl 13(%rdi), %ebp
; SSE41-NEXT: movzbl 14(%rdi), %eax
+; SSE41-NEXT: movzbl 15(%rdi), %edi
+; SSE41-NEXT: movaps %xmm0, -{{[0-9]+}}(%rsp)
+; SSE41-NEXT: movzbl -24(%rsp,%r9), %r9d
+; SSE41-NEXT: movd %r9d, %xmm0
+; SSE41-NEXT: andl $15, %ebx
+; SSE41-NEXT: pinsrb $1, -24(%rsp,%rbx), %xmm0
+; SSE41-NEXT: movq {{[-0-9]+}}(%r{{[sb]}}p), %rbx # 8-byte Reload
+; SSE41-NEXT: andl $15, %ebx
+; SSE41-NEXT: pinsrb $2, -24(%rsp,%rbx), %xmm0
+; SSE41-NEXT: andl $15, %r11d
+; SSE41-NEXT: pinsrb $3, -24(%rsp,%r11), %xmm0
+; SSE41-NEXT: andl $15, %r14d
+; SSE41-NEXT: pinsrb $4, -24(%rsp,%r14), %xmm0
+; SSE41-NEXT: andl $15, %r15d
+; SSE41-NEXT: pinsrb $5, -24(%rsp,%r15), %xmm0
+; SSE41-NEXT: andl $15, %r12d
+; SSE41-NEXT: pinsrb $6, -24(%rsp,%r12), %xmm0
+; SSE41-NEXT: andl $15, %r13d
+; SSE41-NEXT: pinsrb $7, -24(%rsp,%r13), %xmm0
+; SSE41-NEXT: andl $15, %r10d
+; SSE41-NEXT: pinsrb $8, -24(%rsp,%r10), %xmm0
+; SSE41-NEXT: andl $15, %r8d
+; SSE41-NEXT: pinsrb $9, -24(%rsp,%r8), %xmm0
+; SSE41-NEXT: andl $15, %ecx
+; SSE41-NEXT: pinsrb $10, -24(%rsp,%rcx), %xmm0
+; SSE41-NEXT: andl $15, %edx
+; SSE41-NEXT: pinsrb $11, -24(%rsp,%rdx), %xmm0
+; SSE41-NEXT: andl $15, %esi
+; SSE41-NEXT: pinsrb $12, -24(%rsp,%rsi), %xmm0
+; SSE41-NEXT: andl $15, %ebp
+; SSE41-NEXT: pinsrb $13, -24(%rsp,%rbp), %xmm0
; SSE41-NEXT: andl $15, %eax
; SSE41-NEXT: pinsrb $14, -24(%rsp,%rax), %xmm0
-; SSE41-NEXT: movzbl 15(%rdi), %eax
-; SSE41-NEXT: andl $15, %eax
-; SSE41-NEXT: pinsrb $15, -24(%rsp,%rax), %xmm0
+; SSE41-NEXT: andl $15, %edi
+; SSE41-NEXT: pinsrb $15, -24(%rsp,%rdi), %xmm0
+; SSE41-NEXT: popq %rbx
+; SSE41-NEXT: popq %r12
+; SSE41-NEXT: popq %r13
+; SSE41-NEXT: popq %r14
+; SSE41-NEXT: popq %r15
+; SSE41-NEXT: popq %rbp
; SSE41-NEXT: retq
;
; AVX-LABEL: mem_shuffle_v16i8_v16i8_xxxxxxxxxxxxxxxx_i8:
; AVX: # %bb.0:
-; AVX-NEXT: movzbl (%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vmovaps %xmm0, -{{[0-9]+}}(%rsp)
-; AVX-NEXT: movzbl -24(%rsp,%rax), %eax
-; AVX-NEXT: vmovd %eax, %xmm0
-; AVX-NEXT: movzbl 1(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $1, -24(%rsp,%rax), %xmm0, %xmm0
+; AVX-NEXT: pushq %rbp
+; AVX-NEXT: pushq %r15
+; AVX-NEXT: pushq %r14
+; AVX-NEXT: pushq %r13
+; AVX-NEXT: pushq %r12
+; AVX-NEXT: pushq %rbx
+; AVX-NEXT: movzbl (%rdi), %r9d
+; AVX-NEXT: andl $15, %r9d
+; AVX-NEXT: movzbl 1(%rdi), %ebx
; AVX-NEXT: movzbl 2(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $2, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 3(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $3, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 4(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $4, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 5(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $5, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 6(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $6, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 7(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $7, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 8(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $8, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 9(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $9, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 10(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $10, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 11(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $11, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 12(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $12, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 13(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $13, -24(%rsp,%rax), %xmm0, %xmm0
+; AVX-NEXT: movq %rax, {{[-0-9]+}}(%r{{[sb]}}p) # 8-byte Spill
+; AVX-NEXT: movzbl 3(%rdi), %r11d
+; AVX-NEXT: movzbl 4(%rdi), %r14d
+; AVX-NEXT: movzbl 5(%rdi), %r15d
+; AVX-NEXT: movzbl 6(%rdi), %r12d
+; AVX-NEXT: movzbl 7(%rdi), %r13d
+; AVX-NEXT: movzbl 8(%rdi), %r10d
+; AVX-NEXT: movzbl 9(%rdi), %r8d
+; AVX-NEXT: movzbl 10(%rdi), %ecx
+; AVX-NEXT: movzbl 11(%rdi), %edx
+; AVX-NEXT: movzbl 12(%rdi), %esi
+; AVX-NEXT: movzbl 13(%rdi), %ebp
; AVX-NEXT: movzbl 14(%rdi), %eax
+; AVX-NEXT: movzbl 15(%rdi), %edi
+; AVX-NEXT: vmovaps %xmm0, -{{[0-9]+}}(%rsp)
+; AVX-NEXT: movzbl -24(%rsp,%r9), %r9d
+; AVX-NEXT: vmovd %r9d, %xmm0
+; AVX-NEXT: andl $15, %ebx
+; AVX-NEXT: vpinsrb $1, -24(%rsp,%rbx), %xmm0, %xmm0
+; AVX-NEXT: movq {{[-0-9]+}}(%r{{[sb]}}p), %rbx # 8-byte Reload
+; AVX-NEXT: andl $15, %ebx
+; AVX-NEXT: vpinsrb $2, -24(%rsp,%rbx), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %r11d
+; AVX-NEXT: vpinsrb $3, -24(%rsp,%r11), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %r14d
+; AVX-NEXT: vpinsrb $4, -24(%rsp,%r14), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %r15d
+; AVX-NEXT: vpinsrb $5, -24(%rsp,%r15), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %r12d
+; AVX-NEXT: vpinsrb $6, -24(%rsp,%r12), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %r13d
+; AVX-NEXT: vpinsrb $7, -24(%rsp,%r13), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %r10d
+; AVX-NEXT: vpinsrb $8, -24(%rsp,%r10), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %r8d
+; AVX-NEXT: vpinsrb $9, -24(%rsp,%r8), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %ecx
+; AVX-NEXT: vpinsrb $10, -24(%rsp,%rcx), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %edx
+; AVX-NEXT: vpinsrb $11, -24(%rsp,%rdx), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %esi
+; AVX-NEXT: vpinsrb $12, -24(%rsp,%rsi), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %ebp
+; AVX-NEXT: vpinsrb $13, -24(%rsp,%rbp), %xmm0, %xmm0
; AVX-NEXT: andl $15, %eax
; AVX-NEXT: vpinsrb $14, -24(%rsp,%rax), %xmm0, %xmm0
-; AVX-NEXT: movzbl 15(%rdi), %eax
-; AVX-NEXT: andl $15, %eax
-; AVX-NEXT: vpinsrb $15, -24(%rsp,%rax), %xmm0, %xmm0
+; AVX-NEXT: andl $15, %edi
+; AVX-NEXT: vpinsrb $15, -24(%rsp,%rdi), %xmm0, %xmm0
+; AVX-NEXT: popq %rbx
+; AVX-NEXT: popq %r12
+; AVX-NEXT: popq %r13
+; AVX-NEXT: popq %r14
+; AVX-NEXT: popq %r15
+; AVX-NEXT: popq %rbp
; AVX-NEXT: retq
%p0 = getelementptr inbounds i8, i8* %i, i64 0
%p1 = getelementptr inbounds i8, i8* %i, i64 1