[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / AArch64 / sve-sext-zext.ll
blob24cf433306bb5c4094b333b7eb4d7af773e6a7a9
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc -mtriple=aarch64--linux-gnu -mattr=+sve < %s | FileCheck %s
4 define <vscale x 16 x i8> @sext_i1_i8(<vscale x 16 x i1> %a) {
5 ; CHECK-LABEL: sext_i1_i8:
6 ; CHECK:       // %bb.0:
7 ; CHECK-NEXT:    mov z0.b, p0/z, #-1 // =0xffffffffffffffff
8 ; CHECK-NEXT:    ret
9   %r = sext <vscale x 16 x i1> %a to <vscale x 16 x i8>
10   ret <vscale x 16 x i8> %r
13 define <vscale x 8 x i16> @sext_i1_i16(<vscale x 8 x i1> %a) {
14 ; CHECK-LABEL: sext_i1_i16:
15 ; CHECK:       // %bb.0:
16 ; CHECK-NEXT:    mov z0.h, p0/z, #-1 // =0xffffffffffffffff
17 ; CHECK-NEXT:    ret
18   %r = sext <vscale x 8 x i1> %a to <vscale x 8 x i16>
19   ret <vscale x 8 x i16> %r
22 define <vscale x 4 x i32> @sext_i1_i32(<vscale x 4 x i1> %a) {
23 ; CHECK-LABEL: sext_i1_i32:
24 ; CHECK:       // %bb.0:
25 ; CHECK-NEXT:    mov z0.s, p0/z, #-1 // =0xffffffffffffffff
26 ; CHECK-NEXT:    ret
27   %r = sext <vscale x 4 x i1> %a to <vscale x 4 x i32>
28   ret <vscale x 4 x i32> %r
31 define <vscale x 2 x i64> @sext_i1_i64(<vscale x 2 x i1> %a) {
32 ; CHECK-LABEL: sext_i1_i64:
33 ; CHECK:       // %bb.0:
34 ; CHECK-NEXT:    mov z0.d, p0/z, #-1 // =0xffffffffffffffff
35 ; CHECK-NEXT:    ret
36   %r = sext <vscale x 2 x i1> %a to <vscale x 2 x i64>
37   ret <vscale x 2 x i64> %r
40 define <vscale x 16 x i8> @zext_i1_i8(<vscale x 16 x i1> %a) {
41 ; CHECK-LABEL: zext_i1_i8:
42 ; CHECK:       // %bb.0:
43 ; CHECK-NEXT:    mov z0.b, p0/z, #1 // =0x1
44 ; CHECK-NEXT:    ret
45   %r = zext <vscale x 16 x i1> %a to <vscale x 16 x i8>
46   ret <vscale x 16 x i8> %r
49 define <vscale x 8 x i16> @zext_i1_i16(<vscale x 8 x i1> %a) {
50 ; CHECK-LABEL: zext_i1_i16:
51 ; CHECK:       // %bb.0:
52 ; CHECK-NEXT:    mov z0.h, p0/z, #1 // =0x1
53 ; CHECK-NEXT:    ret
54   %r = zext <vscale x 8 x i1> %a to <vscale x 8 x i16>
55   ret <vscale x 8 x i16> %r
58 define <vscale x 4 x i32> @zext_i1_i32(<vscale x 4 x i1> %a) {
59 ; CHECK-LABEL: zext_i1_i32:
60 ; CHECK:       // %bb.0:
61 ; CHECK-NEXT:    mov z0.s, p0/z, #1 // =0x1
62 ; CHECK-NEXT:    ret
63   %r = zext <vscale x 4 x i1> %a to <vscale x 4 x i32>
64   ret <vscale x 4 x i32> %r
67 define <vscale x 2 x i64> @zext_i1_i64(<vscale x 2 x i1> %a) {
68 ; CHECK-LABEL: zext_i1_i64:
69 ; CHECK:       // %bb.0:
70 ; CHECK-NEXT:    mov z0.d, p0/z, #1 // =0x1
71 ; CHECK-NEXT:    ret
72   %r = zext <vscale x 2 x i1> %a to <vscale x 2 x i64>
73   ret <vscale x 2 x i64> %r
76 define <vscale x 8 x i16> @sext_i8_i16(<vscale x 8 x i8> %a) {
77 ; CHECK-LABEL: sext_i8_i16:
78 ; CHECK:       // %bb.0:
79 ; CHECK-NEXT:    ptrue p0.h
80 ; CHECK-NEXT:    sxtb z0.h, p0/m, z0.h
81 ; CHECK-NEXT:    ret
82   %r = sext <vscale x 8 x i8> %a to <vscale x 8 x i16>
83   ret <vscale x 8 x i16> %r
86 define <vscale x 4 x i32> @sext_i8_i32(<vscale x 4 x i8> %a) {
87 ; CHECK-LABEL: sext_i8_i32:
88 ; CHECK:       // %bb.0:
89 ; CHECK-NEXT:    ptrue p0.s
90 ; CHECK-NEXT:    sxtb z0.s, p0/m, z0.s
91 ; CHECK-NEXT:    ret
92   %r = sext <vscale x 4 x i8> %a to <vscale x 4 x i32>
93   ret <vscale x 4 x i32> %r
96 define <vscale x 2 x i64> @sext_i8_i64(<vscale x 2 x i8> %a) {
97 ; CHECK-LABEL: sext_i8_i64:
98 ; CHECK:       // %bb.0:
99 ; CHECK-NEXT:    ptrue p0.d
100 ; CHECK-NEXT:    sxtb z0.d, p0/m, z0.d
101 ; CHECK-NEXT:    ret
102   %r = sext <vscale x 2 x i8> %a to <vscale x 2 x i64>
103   ret <vscale x 2 x i64> %r
106 define <vscale x 8 x i16> @zext_i8_i16(<vscale x 8 x i8> %a) {
107 ; CHECK-LABEL: zext_i8_i16:
108 ; CHECK:       // %bb.0:
109 ; CHECK-NEXT:    and z0.h, z0.h, #0xff
110 ; CHECK-NEXT:    ret
111   %r = zext <vscale x 8 x i8> %a to <vscale x 8 x i16>
112   ret <vscale x 8 x i16> %r
115 define <vscale x 4 x i32> @zext_i8_i32(<vscale x 4 x i8> %a) {
116 ; CHECK-LABEL: zext_i8_i32:
117 ; CHECK:       // %bb.0:
118 ; CHECK-NEXT:    and z0.s, z0.s, #0xff
119 ; CHECK-NEXT:    ret
120   %r = zext <vscale x 4 x i8> %a to <vscale x 4 x i32>
121   ret <vscale x 4 x i32> %r
124 define <vscale x 2 x i64> @zext_i8_i64(<vscale x 2 x i8> %a) {
125 ; CHECK-LABEL: zext_i8_i64:
126 ; CHECK:       // %bb.0:
127 ; CHECK-NEXT:    and z0.d, z0.d, #0xff
128 ; CHECK-NEXT:    ret
129   %r = zext <vscale x 2 x i8> %a to <vscale x 2 x i64>
130   ret <vscale x 2 x i64> %r
133 define <vscale x 4 x i32> @sext_i16_i32(<vscale x 4 x i16> %a) {
134 ; CHECK-LABEL: sext_i16_i32:
135 ; CHECK:       // %bb.0:
136 ; CHECK-NEXT:    ptrue p0.s
137 ; CHECK-NEXT:    sxth z0.s, p0/m, z0.s
138 ; CHECK-NEXT:    ret
139   %r = sext <vscale x 4 x i16> %a to <vscale x 4 x i32>
140   ret <vscale x 4 x i32> %r
143 define <vscale x 2 x i64> @sext_i16_i64(<vscale x 2 x i16> %a) {
144 ; CHECK-LABEL: sext_i16_i64:
145 ; CHECK:       // %bb.0:
146 ; CHECK-NEXT:    ptrue p0.d
147 ; CHECK-NEXT:    sxth z0.d, p0/m, z0.d
148 ; CHECK-NEXT:    ret
149   %r = sext <vscale x 2 x i16> %a to <vscale x 2 x i64>
150   ret <vscale x 2 x i64> %r
153 define <vscale x 4 x i32> @zext_i16_i32(<vscale x 4 x i16> %a) {
154 ; CHECK-LABEL: zext_i16_i32:
155 ; CHECK:       // %bb.0:
156 ; CHECK-NEXT:    and z0.s, z0.s, #0xffff
157 ; CHECK-NEXT:    ret
158   %r = zext <vscale x 4 x i16> %a to <vscale x 4 x i32>
159   ret <vscale x 4 x i32> %r
162 define <vscale x 2 x i64> @zext_i16_i64(<vscale x 2 x i16> %a) {
163 ; CHECK-LABEL: zext_i16_i64:
164 ; CHECK:       // %bb.0:
165 ; CHECK-NEXT:    and z0.d, z0.d, #0xffff
166 ; CHECK-NEXT:    ret
167   %r = zext <vscale x 2 x i16> %a to <vscale x 2 x i64>
168   ret <vscale x 2 x i64> %r
171 define <vscale x 2 x i64> @sext_i32_i64(<vscale x 2 x i32> %a) {
172 ; CHECK-LABEL: sext_i32_i64:
173 ; CHECK:       // %bb.0:
174 ; CHECK-NEXT:    ptrue p0.d
175 ; CHECK-NEXT:    sxtw z0.d, p0/m, z0.d
176 ; CHECK-NEXT:    ret
177   %r = sext <vscale x 2 x i32> %a to <vscale x 2 x i64>
178   ret <vscale x 2 x i64> %r
181 define <vscale x 2 x i64> @zext_i32_i64(<vscale x 2 x i32> %a) {
182 ; CHECK-LABEL: zext_i32_i64:
183 ; CHECK:       // %bb.0:
184 ; CHECK-NEXT:    and z0.d, z0.d, #0xffffffff
185 ; CHECK-NEXT:    ret
186   %r = zext <vscale x 2 x i32> %a to <vscale x 2 x i64>
187   ret <vscale x 2 x i64> %r
190 ; Extending to illegal types
192 define <vscale x 16 x i16> @sext_b_to_h(<vscale x 16 x i8> %a) {
193 ; CHECK-LABEL: sext_b_to_h:
194 ; CHECK:       // %bb.0:
195 ; CHECK-NEXT:    sunpklo z2.h, z0.b
196 ; CHECK-NEXT:    sunpkhi z1.h, z0.b
197 ; CHECK-NEXT:    mov z0.d, z2.d
198 ; CHECK-NEXT:    ret
199   %ext = sext <vscale x 16 x i8> %a to <vscale x 16 x i16>
200   ret <vscale x 16 x i16> %ext
203 define <vscale x 8 x i32> @sext_h_to_s(<vscale x 8 x i16> %a) {
204 ; CHECK-LABEL: sext_h_to_s:
205 ; CHECK:       // %bb.0:
206 ; CHECK-NEXT:    sunpklo z2.s, z0.h
207 ; CHECK-NEXT:    sunpkhi z1.s, z0.h
208 ; CHECK-NEXT:    mov z0.d, z2.d
209 ; CHECK-NEXT:    ret
210   %ext = sext <vscale x 8 x i16> %a to <vscale x 8 x i32>
211   ret <vscale x 8 x i32> %ext
214 define <vscale x 4 x i64> @sext_s_to_d(<vscale x 4 x i32> %a) {
215 ; CHECK-LABEL: sext_s_to_d:
216 ; CHECK:       // %bb.0:
217 ; CHECK-NEXT:    sunpklo z2.d, z0.s
218 ; CHECK-NEXT:    sunpkhi z1.d, z0.s
219 ; CHECK-NEXT:    mov z0.d, z2.d
220 ; CHECK-NEXT:    ret
221   %ext = sext <vscale x 4 x i32> %a to <vscale x 4 x i64>
222   ret <vscale x 4 x i64> %ext
225 define <vscale x 16 x i32> @sext_b_to_s(<vscale x 16 x i8> %a) {
226 ; CHECK-LABEL: sext_b_to_s:
227 ; CHECK:       // %bb.0:
228 ; CHECK-NEXT:    sunpklo z1.h, z0.b
229 ; CHECK-NEXT:    sunpkhi z3.h, z0.b
230 ; CHECK-NEXT:    sunpklo z0.s, z1.h
231 ; CHECK-NEXT:    sunpkhi z1.s, z1.h
232 ; CHECK-NEXT:    sunpklo z2.s, z3.h
233 ; CHECK-NEXT:    sunpkhi z3.s, z3.h
234 ; CHECK-NEXT:    ret
235   %ext = sext <vscale x 16 x i8> %a to <vscale x 16 x i32>
236   ret <vscale x 16 x i32> %ext
239 define <vscale x 16 x i64> @sext_b_to_d(<vscale x 16 x i8> %a) {
240 ; CHECK-LABEL: sext_b_to_d:
241 ; CHECK:       // %bb.0:
242 ; CHECK-NEXT:    sunpklo z1.h, z0.b
243 ; CHECK-NEXT:    sunpkhi z0.h, z0.b
244 ; CHECK-NEXT:    sunpklo z2.s, z1.h
245 ; CHECK-NEXT:    sunpkhi z3.s, z1.h
246 ; CHECK-NEXT:    sunpklo z5.s, z0.h
247 ; CHECK-NEXT:    sunpkhi z7.s, z0.h
248 ; CHECK-NEXT:    sunpklo z0.d, z2.s
249 ; CHECK-NEXT:    sunpkhi z1.d, z2.s
250 ; CHECK-NEXT:    sunpklo z2.d, z3.s
251 ; CHECK-NEXT:    sunpkhi z3.d, z3.s
252 ; CHECK-NEXT:    sunpklo z4.d, z5.s
253 ; CHECK-NEXT:    sunpkhi z5.d, z5.s
254 ; CHECK-NEXT:    sunpklo z6.d, z7.s
255 ; CHECK-NEXT:    sunpkhi z7.d, z7.s
256 ; CHECK-NEXT:    ret
257   %ext = sext <vscale x 16 x i8> %a to <vscale x 16 x i64>
258   ret <vscale x 16 x i64> %ext
261 define <vscale x 16 x i16> @zext_b_to_h(<vscale x 16 x i8> %a) {
262 ; CHECK-LABEL: zext_b_to_h:
263 ; CHECK:       // %bb.0:
264 ; CHECK-NEXT:    uunpklo z2.h, z0.b
265 ; CHECK-NEXT:    uunpkhi z1.h, z0.b
266 ; CHECK-NEXT:    mov z0.d, z2.d
267 ; CHECK-NEXT:    ret
268   %ext = zext <vscale x 16 x i8> %a to <vscale x 16 x i16>
269   ret <vscale x 16 x i16> %ext
272 define <vscale x 8 x i32> @zext_h_to_s(<vscale x 8 x i16> %a) {
273 ; CHECK-LABEL: zext_h_to_s:
274 ; CHECK:       // %bb.0:
275 ; CHECK-NEXT:    uunpklo z2.s, z0.h
276 ; CHECK-NEXT:    uunpkhi z1.s, z0.h
277 ; CHECK-NEXT:    mov z0.d, z2.d
278 ; CHECK-NEXT:    ret
279   %ext = zext <vscale x 8 x i16> %a to <vscale x 8 x i32>
280   ret <vscale x 8 x i32> %ext
283 define <vscale x 4 x i64> @zext_s_to_d(<vscale x 4 x i32> %a) {
284 ; CHECK-LABEL: zext_s_to_d:
285 ; CHECK:       // %bb.0:
286 ; CHECK-NEXT:    uunpklo z2.d, z0.s
287 ; CHECK-NEXT:    uunpkhi z1.d, z0.s
288 ; CHECK-NEXT:    mov z0.d, z2.d
289 ; CHECK-NEXT:    ret
290   %ext = zext <vscale x 4 x i32> %a to <vscale x 4 x i64>
291   ret <vscale x 4 x i64> %ext
294 define <vscale x 16 x i32> @zext_b_to_s(<vscale x 16 x i8> %a) {
295 ; CHECK-LABEL: zext_b_to_s:
296 ; CHECK:       // %bb.0:
297 ; CHECK-NEXT:    uunpklo z1.h, z0.b
298 ; CHECK-NEXT:    uunpkhi z3.h, z0.b
299 ; CHECK-NEXT:    uunpklo z0.s, z1.h
300 ; CHECK-NEXT:    uunpkhi z1.s, z1.h
301 ; CHECK-NEXT:    uunpklo z2.s, z3.h
302 ; CHECK-NEXT:    uunpkhi z3.s, z3.h
303 ; CHECK-NEXT:    ret
304   %ext = zext <vscale x 16 x i8> %a to <vscale x 16 x i32>
305   ret <vscale x 16 x i32> %ext
308 define <vscale x 16 x i64> @zext_b_to_d(<vscale x 16 x i8> %a) {
309 ; CHECK-LABEL: zext_b_to_d:
310 ; CHECK:       // %bb.0:
311 ; CHECK-NEXT:    uunpklo z1.h, z0.b
312 ; CHECK-NEXT:    uunpkhi z0.h, z0.b
313 ; CHECK-NEXT:    uunpklo z2.s, z1.h
314 ; CHECK-NEXT:    uunpkhi z3.s, z1.h
315 ; CHECK-NEXT:    uunpklo z5.s, z0.h
316 ; CHECK-NEXT:    uunpkhi z7.s, z0.h
317 ; CHECK-NEXT:    uunpklo z0.d, z2.s
318 ; CHECK-NEXT:    uunpkhi z1.d, z2.s
319 ; CHECK-NEXT:    uunpklo z2.d, z3.s
320 ; CHECK-NEXT:    uunpkhi z3.d, z3.s
321 ; CHECK-NEXT:    uunpklo z4.d, z5.s
322 ; CHECK-NEXT:    uunpkhi z5.d, z5.s
323 ; CHECK-NEXT:    uunpklo z6.d, z7.s
324 ; CHECK-NEXT:    uunpkhi z7.d, z7.s
325 ; CHECK-NEXT:    ret
326   %ext = zext <vscale x 16 x i8> %a to <vscale x 16 x i64>
327   ret <vscale x 16 x i64> %ext