xref: /llvm-project/llvm/test/CodeGen/X86/legalize-ins-ext-vec-elt.ll (revision 445973caceea9154b7f05a0b574ced346955be87)
1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
2; RUN: llc -mtriple=x86_64-- -o - %s| FileCheck %s
3
4; Verify that we support non byte-sized elements, together with variable index.
5
6define void @Legalize_SplitVectorResult_insert_i28(i28 %elt, i16 %idx, ptr %p1, ptr %p2) nounwind {
7; CHECK-LABEL: Legalize_SplitVectorResult_insert_i28:
8; CHECK:       # %bb.0:
9; CHECK-NEXT:    # kill: def $esi killed $esi def $rsi
10; CHECK-NEXT:    xorps %xmm0, %xmm0
11; CHECK-NEXT:    movaps %xmm0, -{{[0-9]+}}(%rsp)
12; CHECK-NEXT:    movaps %xmm0, -{{[0-9]+}}(%rsp)
13; CHECK-NEXT:    andl $7, %esi
14; CHECK-NEXT:    movl %edi, -40(%rsp,%rsi,4)
15; CHECK-NEXT:    movaps {{.*#+}} xmm0 = [268435455,268435455,268435455,268435455]
16; CHECK-NEXT:    movaps -{{[0-9]+}}(%rsp), %xmm1
17; CHECK-NEXT:    andps %xmm0, %xmm1
18; CHECK-NEXT:    andps -{{[0-9]+}}(%rsp), %xmm0
19; CHECK-NEXT:    movaps %xmm0, 16(%rcx)
20; CHECK-NEXT:    movaps %xmm1, (%rcx)
21; CHECK-NEXT:    retq
22  %vec1 = insertelement <8 x i28> zeroinitializer, i28 %elt, i16 %idx
23  %vec2 = zext <8 x i28> %vec1 to <8 x i32>
24  store <8 x i32> %vec2, ptr %p2
25  ret void
26}
27
28define void @Legalize_SplitVectorResult_extract_i12(i16 %idx, ptr %p1, ptr %p2) nounwind {
29; CHECK-LABEL: Legalize_SplitVectorResult_extract_i12:
30; CHECK:       # %bb.0:
31; CHECK-NEXT:    pushq %rax
32; CHECK-NEXT:    # kill: def $edi killed $edi def $rdi
33; CHECK-NEXT:    movaps (%rsi), %xmm0
34; CHECK-NEXT:    movaps 16(%rsi), %xmm1
35; CHECK-NEXT:    movaps 32(%rsi), %xmm2
36; CHECK-NEXT:    movaps 48(%rsi), %xmm3
37; CHECK-NEXT:    movaps 64(%rsi), %xmm4
38; CHECK-NEXT:    movaps 80(%rsi), %xmm5
39; CHECK-NEXT:    movaps 96(%rsi), %xmm6
40; CHECK-NEXT:    movaps 112(%rsi), %xmm7
41; CHECK-NEXT:    movaps %xmm7, -{{[0-9]+}}(%rsp)
42; CHECK-NEXT:    movaps %xmm6, -{{[0-9]+}}(%rsp)
43; CHECK-NEXT:    movaps %xmm5, -{{[0-9]+}}(%rsp)
44; CHECK-NEXT:    movaps %xmm4, -{{[0-9]+}}(%rsp)
45; CHECK-NEXT:    movaps %xmm3, -{{[0-9]+}}(%rsp)
46; CHECK-NEXT:    movaps %xmm2, -{{[0-9]+}}(%rsp)
47; CHECK-NEXT:    movaps %xmm1, -{{[0-9]+}}(%rsp)
48; CHECK-NEXT:    movaps %xmm0, -{{[0-9]+}}(%rsp)
49; CHECK-NEXT:    andl $63, %edi
50; CHECK-NEXT:    movzwl -128(%rsp,%rdi,2), %eax
51; CHECK-NEXT:    andl $4095, %eax # imm = 0xFFF
52; CHECK-NEXT:    movw %ax, (%rdx)
53; CHECK-NEXT:    popq %rax
54; CHECK-NEXT:    retq
55  %vec = load <64 x i16>, ptr %p1
56  %trunc = trunc <64 x i16> %vec to <64 x i12>
57  %elt = extractelement <64 x i12> %trunc, i16 %idx
58  store i12 %elt, ptr %p2
59  ret void
60}
61