1 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+avx512f -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
3 # RUN: llc -mtriple=x86_64-linux-gnu -mattr=+avx512f -run-pass=instruction-select -verify-machineinstrs %s -o - | FileCheck %s --check-prefix=ALL
6 define void @test_extract_128_idx0() {
10 define void @test_extract_128_idx1() {
14 define void @test_extract_256_idx0() {
18 define void @test_extract_256_idx1() {
24 name: test_extract_128_idx0
25 # ALL-LABEL: name: test_extract_128_idx0
30 # ALL-NEXT: - { id: 0, class: vr512, preferred-register: '', flags: [ ] }
31 # ALL-NEXT: - { id: 1, class: vr128x, preferred-register: '', flags: [ ] }
33 - { id: 0, class: vecr }
34 - { id: 1, class: vecr }
35 # ALL: %0:vr512 = COPY $zmm1
36 # ALL-NEXT: %1:vr128x = COPY %0.sub_xmm
37 # ALL-NEXT: $xmm0 = COPY %1
38 # ALL-NEXT: RET 0, implicit $xmm0
43 %0(<16 x s32>) = COPY $zmm1
44 %1(<4 x s32>) = G_EXTRACT %0(<16 x s32>), 0
45 $xmm0 = COPY %1(<4 x s32>)
50 name: test_extract_128_idx1
51 # ALL-LABEL: name: test_extract_128_idx1
56 # ALL-NEXT: - { id: 0, class: vr512, preferred-register: '', flags: [ ] }
57 # ALL-NEXT: - { id: 1, class: vr128x, preferred-register: '', flags: [ ] }
59 - { id: 0, class: vecr }
60 - { id: 1, class: vecr }
61 # ALL: %0:vr512 = COPY $zmm1
62 # ALL-NEXT: %1:vr128x = VEXTRACTF32X4Zrri %0, 1
63 # ALL-NEXT: $xmm0 = COPY %1
64 # ALL-NEXT: RET 0, implicit $xmm0
69 %0(<16 x s32>) = COPY $zmm1
70 %1(<4 x s32>) = G_EXTRACT %0(<16 x s32>), 128
71 $xmm0 = COPY %1(<4 x s32>)
76 name: test_extract_256_idx0
77 # ALL-LABEL: name: test_extract_256_idx0
82 # ALL-NEXT: - { id: 0, class: vr512, preferred-register: '', flags: [ ] }
83 # ALL-NEXT: - { id: 1, class: vr256x, preferred-register: '', flags: [ ] }
85 - { id: 0, class: vecr }
86 - { id: 1, class: vecr }
87 # ALL: %0:vr512 = COPY $zmm1
88 # ALL-NEXT: %1:vr256x = COPY %0.sub_ymm
89 # ALL-NEXT: $ymm0 = COPY %1
90 # ALL-NEXT: RET 0, implicit $ymm0
95 %0(<16 x s32>) = COPY $zmm1
96 %1(<8 x s32>) = G_EXTRACT %0(<16 x s32>), 0
97 $ymm0 = COPY %1(<8 x s32>)
102 name: test_extract_256_idx1
103 # ALL-LABEL: name: test_extract_256_idx1
106 regBankSelected: true
108 # ALL-NEXT: - { id: 0, class: vr512, preferred-register: '', flags: [ ] }
109 # ALL-NEXT: - { id: 1, class: vr256x, preferred-register: '', flags: [ ] }
111 - { id: 0, class: vecr }
112 - { id: 1, class: vecr }
113 # ALL: %0:vr512 = COPY $zmm1
114 # ALL-NEXT: %1:vr256x = VEXTRACTF64X4Zrri %0, 1
115 # ALL-NEXT: $ymm0 = COPY %1
116 # ALL-NEXT: RET 0, implicit $ymm0
121 %0(<16 x s32>) = COPY $zmm1
122 %1(<8 x s32>) = G_EXTRACT %0(<16 x s32>), 256
123 $ymm0 = COPY %1(<8 x s32>)
124 RET 0, implicit $ymm0