[X86][AVX512] Regenerate element insertion/extraction tests

llvm-svn: 315322
This commit is contained in:
Simon Pilgrim 2017-10-10 15:58:54 +00:00
parent 9003dd7824
commit 053a299a9b
1 changed files with 171 additions and 352 deletions

View File

@ -1280,81 +1280,45 @@ define i64 @test_extractelement_variable_v2i64(<2 x i64> %t1, i32 %index) {
} }
define i64 @test_extractelement_variable_v4i64(<4 x i64> %t1, i32 %index) { define i64 @test_extractelement_variable_v4i64(<4 x i64> %t1, i32 %index) {
; KNL-LABEL: test_extractelement_variable_v4i64: ; CHECK-LABEL: test_extractelement_variable_v4i64:
; KNL: ## BB#0: ; CHECK: ## BB#0:
; KNL-NEXT: pushq %rbp ; CHECK-NEXT: pushq %rbp
; KNL-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: .cfi_def_cfa_offset 16
; KNL-NEXT: .cfi_offset %rbp, -16 ; CHECK-NEXT: .cfi_offset %rbp, -16
; KNL-NEXT: movq %rsp, %rbp ; CHECK-NEXT: movq %rsp, %rbp
; KNL-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp
; KNL-NEXT: andq $-32, %rsp ; CHECK-NEXT: andq $-32, %rsp
; KNL-NEXT: subq $64, %rsp ; CHECK-NEXT: subq $64, %rsp
; KNL-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def> ; CHECK-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; KNL-NEXT: vmovaps %ymm0, (%rsp) ; CHECK-NEXT: vmovaps %ymm0, (%rsp)
; KNL-NEXT: andl $3, %edi ; CHECK-NEXT: andl $3, %edi
; KNL-NEXT: movq (%rsp,%rdi,8), %rax ; CHECK-NEXT: movq (%rsp,%rdi,8), %rax
; KNL-NEXT: movq %rbp, %rsp ; CHECK-NEXT: movq %rbp, %rsp
; KNL-NEXT: popq %rbp ; CHECK-NEXT: popq %rbp
; KNL-NEXT: vzeroupper ; CHECK-NEXT: vzeroupper
; KNL-NEXT: retq ; CHECK-NEXT: retq
;
; SKX-LABEL: test_extractelement_variable_v4i64:
; SKX: ## BB#0:
; SKX-NEXT: pushq %rbp
; SKX-NEXT: .cfi_def_cfa_offset 16
; SKX-NEXT: .cfi_offset %rbp, -16
; SKX-NEXT: movq %rsp, %rbp
; SKX-NEXT: .cfi_def_cfa_register %rbp
; SKX-NEXT: andq $-32, %rsp
; SKX-NEXT: subq $64, %rsp
; SKX-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; SKX-NEXT: vmovaps %ymm0, (%rsp)
; SKX-NEXT: andl $3, %edi
; SKX-NEXT: movq (%rsp,%rdi,8), %rax
; SKX-NEXT: movq %rbp, %rsp
; SKX-NEXT: popq %rbp
; SKX-NEXT: vzeroupper
; SKX-NEXT: retq
%t2 = extractelement <4 x i64> %t1, i32 %index %t2 = extractelement <4 x i64> %t1, i32 %index
ret i64 %t2 ret i64 %t2
} }
define i64 @test_extractelement_variable_v8i64(<8 x i64> %t1, i32 %index) { define i64 @test_extractelement_variable_v8i64(<8 x i64> %t1, i32 %index) {
; KNL-LABEL: test_extractelement_variable_v8i64: ; CHECK-LABEL: test_extractelement_variable_v8i64:
; KNL: ## BB#0: ; CHECK: ## BB#0:
; KNL-NEXT: pushq %rbp ; CHECK-NEXT: pushq %rbp
; KNL-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: .cfi_def_cfa_offset 16
; KNL-NEXT: .cfi_offset %rbp, -16 ; CHECK-NEXT: .cfi_offset %rbp, -16
; KNL-NEXT: movq %rsp, %rbp ; CHECK-NEXT: movq %rsp, %rbp
; KNL-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp
; KNL-NEXT: andq $-64, %rsp ; CHECK-NEXT: andq $-64, %rsp
; KNL-NEXT: subq $128, %rsp ; CHECK-NEXT: subq $128, %rsp
; KNL-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def> ; CHECK-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; KNL-NEXT: vmovaps %zmm0, (%rsp) ; CHECK-NEXT: vmovaps %zmm0, (%rsp)
; KNL-NEXT: andl $7, %edi ; CHECK-NEXT: andl $7, %edi
; KNL-NEXT: movq (%rsp,%rdi,8), %rax ; CHECK-NEXT: movq (%rsp,%rdi,8), %rax
; KNL-NEXT: movq %rbp, %rsp ; CHECK-NEXT: movq %rbp, %rsp
; KNL-NEXT: popq %rbp ; CHECK-NEXT: popq %rbp
; KNL-NEXT: vzeroupper ; CHECK-NEXT: vzeroupper
; KNL-NEXT: retq ; CHECK-NEXT: retq
;
; SKX-LABEL: test_extractelement_variable_v8i64:
; SKX: ## BB#0:
; SKX-NEXT: pushq %rbp
; SKX-NEXT: .cfi_def_cfa_offset 16
; SKX-NEXT: .cfi_offset %rbp, -16
; SKX-NEXT: movq %rsp, %rbp
; SKX-NEXT: .cfi_def_cfa_register %rbp
; SKX-NEXT: andq $-64, %rsp
; SKX-NEXT: subq $128, %rsp
; SKX-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; SKX-NEXT: vmovaps %zmm0, (%rsp)
; SKX-NEXT: andl $7, %edi
; SKX-NEXT: movq (%rsp,%rdi,8), %rax
; SKX-NEXT: movq %rbp, %rsp
; SKX-NEXT: popq %rbp
; SKX-NEXT: vzeroupper
; SKX-NEXT: retq
%t2 = extractelement <8 x i64> %t1, i32 %index %t2 = extractelement <8 x i64> %t1, i32 %index
ret i64 %t2 ret i64 %t2
} }
@ -1372,81 +1336,45 @@ define double @test_extractelement_variable_v2f64(<2 x double> %t1, i32 %index)
} }
define double @test_extractelement_variable_v4f64(<4 x double> %t1, i32 %index) { define double @test_extractelement_variable_v4f64(<4 x double> %t1, i32 %index) {
; KNL-LABEL: test_extractelement_variable_v4f64: ; CHECK-LABEL: test_extractelement_variable_v4f64:
; KNL: ## BB#0: ; CHECK: ## BB#0:
; KNL-NEXT: pushq %rbp ; CHECK-NEXT: pushq %rbp
; KNL-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: .cfi_def_cfa_offset 16
; KNL-NEXT: .cfi_offset %rbp, -16 ; CHECK-NEXT: .cfi_offset %rbp, -16
; KNL-NEXT: movq %rsp, %rbp ; CHECK-NEXT: movq %rsp, %rbp
; KNL-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp
; KNL-NEXT: andq $-32, %rsp ; CHECK-NEXT: andq $-32, %rsp
; KNL-NEXT: subq $64, %rsp ; CHECK-NEXT: subq $64, %rsp
; KNL-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def> ; CHECK-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; KNL-NEXT: vmovaps %ymm0, (%rsp) ; CHECK-NEXT: vmovaps %ymm0, (%rsp)
; KNL-NEXT: andl $3, %edi ; CHECK-NEXT: andl $3, %edi
; KNL-NEXT: vmovsd {{.*#+}} xmm0 = mem[0],zero ; CHECK-NEXT: vmovsd {{.*#+}} xmm0 = mem[0],zero
; KNL-NEXT: movq %rbp, %rsp ; CHECK-NEXT: movq %rbp, %rsp
; KNL-NEXT: popq %rbp ; CHECK-NEXT: popq %rbp
; KNL-NEXT: vzeroupper ; CHECK-NEXT: vzeroupper
; KNL-NEXT: retq ; CHECK-NEXT: retq
;
; SKX-LABEL: test_extractelement_variable_v4f64:
; SKX: ## BB#0:
; SKX-NEXT: pushq %rbp
; SKX-NEXT: .cfi_def_cfa_offset 16
; SKX-NEXT: .cfi_offset %rbp, -16
; SKX-NEXT: movq %rsp, %rbp
; SKX-NEXT: .cfi_def_cfa_register %rbp
; SKX-NEXT: andq $-32, %rsp
; SKX-NEXT: subq $64, %rsp
; SKX-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; SKX-NEXT: vmovaps %ymm0, (%rsp)
; SKX-NEXT: andl $3, %edi
; SKX-NEXT: vmovsd {{.*#+}} xmm0 = mem[0],zero
; SKX-NEXT: movq %rbp, %rsp
; SKX-NEXT: popq %rbp
; SKX-NEXT: vzeroupper
; SKX-NEXT: retq
%t2 = extractelement <4 x double> %t1, i32 %index %t2 = extractelement <4 x double> %t1, i32 %index
ret double %t2 ret double %t2
} }
define double @test_extractelement_variable_v8f64(<8 x double> %t1, i32 %index) { define double @test_extractelement_variable_v8f64(<8 x double> %t1, i32 %index) {
; KNL-LABEL: test_extractelement_variable_v8f64: ; CHECK-LABEL: test_extractelement_variable_v8f64:
; KNL: ## BB#0: ; CHECK: ## BB#0:
; KNL-NEXT: pushq %rbp ; CHECK-NEXT: pushq %rbp
; KNL-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: .cfi_def_cfa_offset 16
; KNL-NEXT: .cfi_offset %rbp, -16 ; CHECK-NEXT: .cfi_offset %rbp, -16
; KNL-NEXT: movq %rsp, %rbp ; CHECK-NEXT: movq %rsp, %rbp
; KNL-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp
; KNL-NEXT: andq $-64, %rsp ; CHECK-NEXT: andq $-64, %rsp
; KNL-NEXT: subq $128, %rsp ; CHECK-NEXT: subq $128, %rsp
; KNL-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def> ; CHECK-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; KNL-NEXT: vmovaps %zmm0, (%rsp) ; CHECK-NEXT: vmovaps %zmm0, (%rsp)
; KNL-NEXT: andl $7, %edi ; CHECK-NEXT: andl $7, %edi
; KNL-NEXT: vmovsd {{.*#+}} xmm0 = mem[0],zero ; CHECK-NEXT: vmovsd {{.*#+}} xmm0 = mem[0],zero
; KNL-NEXT: movq %rbp, %rsp ; CHECK-NEXT: movq %rbp, %rsp
; KNL-NEXT: popq %rbp ; CHECK-NEXT: popq %rbp
; KNL-NEXT: vzeroupper ; CHECK-NEXT: vzeroupper
; KNL-NEXT: retq ; CHECK-NEXT: retq
;
; SKX-LABEL: test_extractelement_variable_v8f64:
; SKX: ## BB#0:
; SKX-NEXT: pushq %rbp
; SKX-NEXT: .cfi_def_cfa_offset 16
; SKX-NEXT: .cfi_offset %rbp, -16
; SKX-NEXT: movq %rsp, %rbp
; SKX-NEXT: .cfi_def_cfa_register %rbp
; SKX-NEXT: andq $-64, %rsp
; SKX-NEXT: subq $128, %rsp
; SKX-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; SKX-NEXT: vmovaps %zmm0, (%rsp)
; SKX-NEXT: andl $7, %edi
; SKX-NEXT: vmovsd {{.*#+}} xmm0 = mem[0],zero
; SKX-NEXT: movq %rbp, %rsp
; SKX-NEXT: popq %rbp
; SKX-NEXT: vzeroupper
; SKX-NEXT: retq
%t2 = extractelement <8 x double> %t1, i32 %index %t2 = extractelement <8 x double> %t1, i32 %index
ret double %t2 ret double %t2
} }
@ -1464,81 +1392,45 @@ define i32 @test_extractelement_variable_v4i32(<4 x i32> %t1, i32 %index) {
} }
define i32 @test_extractelement_variable_v8i32(<8 x i32> %t1, i32 %index) { define i32 @test_extractelement_variable_v8i32(<8 x i32> %t1, i32 %index) {
; KNL-LABEL: test_extractelement_variable_v8i32: ; CHECK-LABEL: test_extractelement_variable_v8i32:
; KNL: ## BB#0: ; CHECK: ## BB#0:
; KNL-NEXT: pushq %rbp ; CHECK-NEXT: pushq %rbp
; KNL-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: .cfi_def_cfa_offset 16
; KNL-NEXT: .cfi_offset %rbp, -16 ; CHECK-NEXT: .cfi_offset %rbp, -16
; KNL-NEXT: movq %rsp, %rbp ; CHECK-NEXT: movq %rsp, %rbp
; KNL-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp
; KNL-NEXT: andq $-32, %rsp ; CHECK-NEXT: andq $-32, %rsp
; KNL-NEXT: subq $64, %rsp ; CHECK-NEXT: subq $64, %rsp
; KNL-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def> ; CHECK-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; KNL-NEXT: vmovaps %ymm0, (%rsp) ; CHECK-NEXT: vmovaps %ymm0, (%rsp)
; KNL-NEXT: andl $7, %edi ; CHECK-NEXT: andl $7, %edi
; KNL-NEXT: movl (%rsp,%rdi,4), %eax ; CHECK-NEXT: movl (%rsp,%rdi,4), %eax
; KNL-NEXT: movq %rbp, %rsp ; CHECK-NEXT: movq %rbp, %rsp
; KNL-NEXT: popq %rbp ; CHECK-NEXT: popq %rbp
; KNL-NEXT: vzeroupper ; CHECK-NEXT: vzeroupper
; KNL-NEXT: retq ; CHECK-NEXT: retq
;
; SKX-LABEL: test_extractelement_variable_v8i32:
; SKX: ## BB#0:
; SKX-NEXT: pushq %rbp
; SKX-NEXT: .cfi_def_cfa_offset 16
; SKX-NEXT: .cfi_offset %rbp, -16
; SKX-NEXT: movq %rsp, %rbp
; SKX-NEXT: .cfi_def_cfa_register %rbp
; SKX-NEXT: andq $-32, %rsp
; SKX-NEXT: subq $64, %rsp
; SKX-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; SKX-NEXT: vmovaps %ymm0, (%rsp)
; SKX-NEXT: andl $7, %edi
; SKX-NEXT: movl (%rsp,%rdi,4), %eax
; SKX-NEXT: movq %rbp, %rsp
; SKX-NEXT: popq %rbp
; SKX-NEXT: vzeroupper
; SKX-NEXT: retq
%t2 = extractelement <8 x i32> %t1, i32 %index %t2 = extractelement <8 x i32> %t1, i32 %index
ret i32 %t2 ret i32 %t2
} }
define i32 @test_extractelement_variable_v16i32(<16 x i32> %t1, i32 %index) { define i32 @test_extractelement_variable_v16i32(<16 x i32> %t1, i32 %index) {
; KNL-LABEL: test_extractelement_variable_v16i32: ; CHECK-LABEL: test_extractelement_variable_v16i32:
; KNL: ## BB#0: ; CHECK: ## BB#0:
; KNL-NEXT: pushq %rbp ; CHECK-NEXT: pushq %rbp
; KNL-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: .cfi_def_cfa_offset 16
; KNL-NEXT: .cfi_offset %rbp, -16 ; CHECK-NEXT: .cfi_offset %rbp, -16
; KNL-NEXT: movq %rsp, %rbp ; CHECK-NEXT: movq %rsp, %rbp
; KNL-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp
; KNL-NEXT: andq $-64, %rsp ; CHECK-NEXT: andq $-64, %rsp
; KNL-NEXT: subq $128, %rsp ; CHECK-NEXT: subq $128, %rsp
; KNL-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def> ; CHECK-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; KNL-NEXT: vmovaps %zmm0, (%rsp) ; CHECK-NEXT: vmovaps %zmm0, (%rsp)
; KNL-NEXT: andl $15, %edi ; CHECK-NEXT: andl $15, %edi
; KNL-NEXT: movl (%rsp,%rdi,4), %eax ; CHECK-NEXT: movl (%rsp,%rdi,4), %eax
; KNL-NEXT: movq %rbp, %rsp ; CHECK-NEXT: movq %rbp, %rsp
; KNL-NEXT: popq %rbp ; CHECK-NEXT: popq %rbp
; KNL-NEXT: vzeroupper ; CHECK-NEXT: vzeroupper
; KNL-NEXT: retq ; CHECK-NEXT: retq
;
; SKX-LABEL: test_extractelement_variable_v16i32:
; SKX: ## BB#0:
; SKX-NEXT: pushq %rbp
; SKX-NEXT: .cfi_def_cfa_offset 16
; SKX-NEXT: .cfi_offset %rbp, -16
; SKX-NEXT: movq %rsp, %rbp
; SKX-NEXT: .cfi_def_cfa_register %rbp
; SKX-NEXT: andq $-64, %rsp
; SKX-NEXT: subq $128, %rsp
; SKX-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; SKX-NEXT: vmovaps %zmm0, (%rsp)
; SKX-NEXT: andl $15, %edi
; SKX-NEXT: movl (%rsp,%rdi,4), %eax
; SKX-NEXT: movq %rbp, %rsp
; SKX-NEXT: popq %rbp
; SKX-NEXT: vzeroupper
; SKX-NEXT: retq
%t2 = extractelement <16 x i32> %t1, i32 %index %t2 = extractelement <16 x i32> %t1, i32 %index
ret i32 %t2 ret i32 %t2
} }
@ -1556,81 +1448,45 @@ define float @test_extractelement_variable_v4f32(<4 x float> %t1, i32 %index) {
} }
define float @test_extractelement_variable_v8f32(<8 x float> %t1, i32 %index) { define float @test_extractelement_variable_v8f32(<8 x float> %t1, i32 %index) {
; KNL-LABEL: test_extractelement_variable_v8f32: ; CHECK-LABEL: test_extractelement_variable_v8f32:
; KNL: ## BB#0: ; CHECK: ## BB#0:
; KNL-NEXT: pushq %rbp ; CHECK-NEXT: pushq %rbp
; KNL-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: .cfi_def_cfa_offset 16
; KNL-NEXT: .cfi_offset %rbp, -16 ; CHECK-NEXT: .cfi_offset %rbp, -16
; KNL-NEXT: movq %rsp, %rbp ; CHECK-NEXT: movq %rsp, %rbp
; KNL-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp
; KNL-NEXT: andq $-32, %rsp ; CHECK-NEXT: andq $-32, %rsp
; KNL-NEXT: subq $64, %rsp ; CHECK-NEXT: subq $64, %rsp
; KNL-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def> ; CHECK-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; KNL-NEXT: vmovaps %ymm0, (%rsp) ; CHECK-NEXT: vmovaps %ymm0, (%rsp)
; KNL-NEXT: andl $7, %edi ; CHECK-NEXT: andl $7, %edi
; KNL-NEXT: vmovss {{.*#+}} xmm0 = mem[0],zero,zero,zero ; CHECK-NEXT: vmovss {{.*#+}} xmm0 = mem[0],zero,zero,zero
; KNL-NEXT: movq %rbp, %rsp ; CHECK-NEXT: movq %rbp, %rsp
; KNL-NEXT: popq %rbp ; CHECK-NEXT: popq %rbp
; KNL-NEXT: vzeroupper ; CHECK-NEXT: vzeroupper
; KNL-NEXT: retq ; CHECK-NEXT: retq
;
; SKX-LABEL: test_extractelement_variable_v8f32:
; SKX: ## BB#0:
; SKX-NEXT: pushq %rbp
; SKX-NEXT: .cfi_def_cfa_offset 16
; SKX-NEXT: .cfi_offset %rbp, -16
; SKX-NEXT: movq %rsp, %rbp
; SKX-NEXT: .cfi_def_cfa_register %rbp
; SKX-NEXT: andq $-32, %rsp
; SKX-NEXT: subq $64, %rsp
; SKX-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; SKX-NEXT: vmovaps %ymm0, (%rsp)
; SKX-NEXT: andl $7, %edi
; SKX-NEXT: vmovss {{.*#+}} xmm0 = mem[0],zero,zero,zero
; SKX-NEXT: movq %rbp, %rsp
; SKX-NEXT: popq %rbp
; SKX-NEXT: vzeroupper
; SKX-NEXT: retq
%t2 = extractelement <8 x float> %t1, i32 %index %t2 = extractelement <8 x float> %t1, i32 %index
ret float %t2 ret float %t2
} }
define float @test_extractelement_variable_v16f32(<16 x float> %t1, i32 %index) { define float @test_extractelement_variable_v16f32(<16 x float> %t1, i32 %index) {
; KNL-LABEL: test_extractelement_variable_v16f32: ; CHECK-LABEL: test_extractelement_variable_v16f32:
; KNL: ## BB#0: ; CHECK: ## BB#0:
; KNL-NEXT: pushq %rbp ; CHECK-NEXT: pushq %rbp
; KNL-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: .cfi_def_cfa_offset 16
; KNL-NEXT: .cfi_offset %rbp, -16 ; CHECK-NEXT: .cfi_offset %rbp, -16
; KNL-NEXT: movq %rsp, %rbp ; CHECK-NEXT: movq %rsp, %rbp
; KNL-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp
; KNL-NEXT: andq $-64, %rsp ; CHECK-NEXT: andq $-64, %rsp
; KNL-NEXT: subq $128, %rsp ; CHECK-NEXT: subq $128, %rsp
; KNL-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def> ; CHECK-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; KNL-NEXT: vmovaps %zmm0, (%rsp) ; CHECK-NEXT: vmovaps %zmm0, (%rsp)
; KNL-NEXT: andl $15, %edi ; CHECK-NEXT: andl $15, %edi
; KNL-NEXT: vmovss {{.*#+}} xmm0 = mem[0],zero,zero,zero ; CHECK-NEXT: vmovss {{.*#+}} xmm0 = mem[0],zero,zero,zero
; KNL-NEXT: movq %rbp, %rsp ; CHECK-NEXT: movq %rbp, %rsp
; KNL-NEXT: popq %rbp ; CHECK-NEXT: popq %rbp
; KNL-NEXT: vzeroupper ; CHECK-NEXT: vzeroupper
; KNL-NEXT: retq ; CHECK-NEXT: retq
;
; SKX-LABEL: test_extractelement_variable_v16f32:
; SKX: ## BB#0:
; SKX-NEXT: pushq %rbp
; SKX-NEXT: .cfi_def_cfa_offset 16
; SKX-NEXT: .cfi_offset %rbp, -16
; SKX-NEXT: movq %rsp, %rbp
; SKX-NEXT: .cfi_def_cfa_register %rbp
; SKX-NEXT: andq $-64, %rsp
; SKX-NEXT: subq $128, %rsp
; SKX-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; SKX-NEXT: vmovaps %zmm0, (%rsp)
; SKX-NEXT: andl $15, %edi
; SKX-NEXT: vmovss {{.*#+}} xmm0 = mem[0],zero,zero,zero
; SKX-NEXT: movq %rbp, %rsp
; SKX-NEXT: popq %rbp
; SKX-NEXT: vzeroupper
; SKX-NEXT: retq
%t2 = extractelement <16 x float> %t1, i32 %index %t2 = extractelement <16 x float> %t1, i32 %index
ret float %t2 ret float %t2
} }
@ -1648,41 +1504,23 @@ define i16 @test_extractelement_variable_v8i16(<8 x i16> %t1, i32 %index) {
} }
define i16 @test_extractelement_variable_v16i16(<16 x i16> %t1, i32 %index) { define i16 @test_extractelement_variable_v16i16(<16 x i16> %t1, i32 %index) {
; KNL-LABEL: test_extractelement_variable_v16i16: ; CHECK-LABEL: test_extractelement_variable_v16i16:
; KNL: ## BB#0: ; CHECK: ## BB#0:
; KNL-NEXT: pushq %rbp ; CHECK-NEXT: pushq %rbp
; KNL-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: .cfi_def_cfa_offset 16
; KNL-NEXT: .cfi_offset %rbp, -16 ; CHECK-NEXT: .cfi_offset %rbp, -16
; KNL-NEXT: movq %rsp, %rbp ; CHECK-NEXT: movq %rsp, %rbp
; KNL-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp
; KNL-NEXT: andq $-32, %rsp ; CHECK-NEXT: andq $-32, %rsp
; KNL-NEXT: subq $64, %rsp ; CHECK-NEXT: subq $64, %rsp
; KNL-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def> ; CHECK-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; KNL-NEXT: vmovaps %ymm0, (%rsp) ; CHECK-NEXT: vmovaps %ymm0, (%rsp)
; KNL-NEXT: andl $15, %edi ; CHECK-NEXT: andl $15, %edi
; KNL-NEXT: movzwl (%rsp,%rdi,2), %eax ; CHECK-NEXT: movzwl (%rsp,%rdi,2), %eax
; KNL-NEXT: movq %rbp, %rsp ; CHECK-NEXT: movq %rbp, %rsp
; KNL-NEXT: popq %rbp ; CHECK-NEXT: popq %rbp
; KNL-NEXT: vzeroupper ; CHECK-NEXT: vzeroupper
; KNL-NEXT: retq ; CHECK-NEXT: retq
;
; SKX-LABEL: test_extractelement_variable_v16i16:
; SKX: ## BB#0:
; SKX-NEXT: pushq %rbp
; SKX-NEXT: .cfi_def_cfa_offset 16
; SKX-NEXT: .cfi_offset %rbp, -16
; SKX-NEXT: movq %rsp, %rbp
; SKX-NEXT: .cfi_def_cfa_register %rbp
; SKX-NEXT: andq $-32, %rsp
; SKX-NEXT: subq $64, %rsp
; SKX-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; SKX-NEXT: vmovaps %ymm0, (%rsp)
; SKX-NEXT: andl $15, %edi
; SKX-NEXT: movzwl (%rsp,%rdi,2), %eax
; SKX-NEXT: movq %rbp, %rsp
; SKX-NEXT: popq %rbp
; SKX-NEXT: vzeroupper
; SKX-NEXT: retq
%t2 = extractelement <16 x i16> %t1, i32 %index %t2 = extractelement <16 x i16> %t1, i32 %index
ret i16 %t2 ret i16 %t2
} }
@ -1742,43 +1580,24 @@ define i8 @test_extractelement_variable_v16i8(<16 x i8> %t1, i32 %index) {
} }
define i8 @test_extractelement_variable_v32i8(<32 x i8> %t1, i32 %index) { define i8 @test_extractelement_variable_v32i8(<32 x i8> %t1, i32 %index) {
; KNL-LABEL: test_extractelement_variable_v32i8: ; CHECK-LABEL: test_extractelement_variable_v32i8:
; KNL: ## BB#0: ; CHECK: ## BB#0:
; KNL-NEXT: pushq %rbp ; CHECK-NEXT: pushq %rbp
; KNL-NEXT: .cfi_def_cfa_offset 16 ; CHECK-NEXT: .cfi_def_cfa_offset 16
; KNL-NEXT: .cfi_offset %rbp, -16 ; CHECK-NEXT: .cfi_offset %rbp, -16
; KNL-NEXT: movq %rsp, %rbp ; CHECK-NEXT: movq %rsp, %rbp
; KNL-NEXT: .cfi_def_cfa_register %rbp ; CHECK-NEXT: .cfi_def_cfa_register %rbp
; KNL-NEXT: andq $-32, %rsp ; CHECK-NEXT: andq $-32, %rsp
; KNL-NEXT: subq $64, %rsp ; CHECK-NEXT: subq $64, %rsp
; KNL-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def> ; CHECK-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; KNL-NEXT: vmovaps %ymm0, (%rsp) ; CHECK-NEXT: vmovaps %ymm0, (%rsp)
; KNL-NEXT: andl $31, %edi ; CHECK-NEXT: andl $31, %edi
; KNL-NEXT: movq %rsp, %rax ; CHECK-NEXT: movq %rsp, %rax
; KNL-NEXT: movb (%rdi,%rax), %al ; CHECK-NEXT: movb (%rdi,%rax), %al
; KNL-NEXT: movq %rbp, %rsp ; CHECK-NEXT: movq %rbp, %rsp
; KNL-NEXT: popq %rbp ; CHECK-NEXT: popq %rbp
; KNL-NEXT: vzeroupper ; CHECK-NEXT: vzeroupper
; KNL-NEXT: retq ; CHECK-NEXT: retq
;
; SKX-LABEL: test_extractelement_variable_v32i8:
; SKX: ## BB#0:
; SKX-NEXT: pushq %rbp
; SKX-NEXT: .cfi_def_cfa_offset 16
; SKX-NEXT: .cfi_offset %rbp, -16
; SKX-NEXT: movq %rsp, %rbp
; SKX-NEXT: .cfi_def_cfa_register %rbp
; SKX-NEXT: andq $-32, %rsp
; SKX-NEXT: subq $64, %rsp
; SKX-NEXT: ## kill: %EDI<def> %EDI<kill> %RDI<def>
; SKX-NEXT: vmovaps %ymm0, (%rsp)
; SKX-NEXT: andl $31, %edi
; SKX-NEXT: movq %rsp, %rax
; SKX-NEXT: movb (%rdi,%rax), %al
; SKX-NEXT: movq %rbp, %rsp
; SKX-NEXT: popq %rbp
; SKX-NEXT: vzeroupper
; SKX-NEXT: retq
%t2 = extractelement <32 x i8> %t1, i32 %index %t2 = extractelement <32 x i8> %t1, i32 %index
ret i8 %t2 ret i8 %t2