[ORC] Add std::tuple support to SimplePackedSerialization.
[llvm-project.git] / llvm / test / CodeGen / AArch64 / sve-unary-movprfx.ll
bloba29aebfb001b79dcfc80aafe988110bdbbf5083f
1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s | FileCheck %s
4 target triple = "aarch64-unknown-linux-gnu"
7 ; ABS (sve_int_un_pred_arit_0)
10 ; Check movprfx is inserted when no passthru/predicate is present
11 define <vscale x 16 x i8> @abs_i8(<vscale x 16 x i8> %a, <vscale x 16 x i8> %b) #0 {
12 ; CHECK-LABEL: abs_i8:
13 ; CHECK:       // %bb.0:
14 ; CHECK-NEXT:    ptrue p0.b
15 ; CHECK-NEXT:    movprfx z0, z1
16 ; CHECK-NEXT:    abs z0.b, p0/m, z1.b
17 ; CHECK-NEXT:    ret
18   %ret = tail call <vscale x 16 x i8> @llvm.abs.nxv16i8(<vscale x 16 x i8> %b, i1 0)
19   ret <vscale x 16 x i8> %ret
22 ; Check movprfx is not inserted when dstReg == srcReg
23 define <vscale x 16 x i8> @abs_i8_dupreg(<vscale x 16 x i8> %a) #0 {
24 ; CHECK-LABEL: abs_i8_dupreg:
25 ; CHECK:       // %bb.0:
26 ; CHECK-NEXT:    ptrue p0.b
27 ; CHECK-NEXT:    abs z0.b, p0/m, z0.b
28 ; CHECK-NEXT:    ret
29   %ret = tail call <vscale x 16 x i8> @llvm.abs.nxv16i8(<vscale x 16 x i8> %a, i1 0)
30   ret <vscale x 16 x i8> %ret
33 ; Check movprfx is inserted when passthru is undef
34 define <vscale x 16 x i8> @abs_i8_undef(<vscale x 16 x i8> %a, <vscale x 16 x i8> %b) #0 {
35 ; CHECK-LABEL: abs_i8_undef:
36 ; CHECK:       // %bb.0:
37 ; CHECK-NEXT:    ptrue p0.b
38 ; CHECK-NEXT:    movprfx z0, z1
39 ; CHECK-NEXT:    abs z0.b, p0/m, z1.b
40 ; CHECK-NEXT:    ret
41   %pg = tail call <vscale x 16 x i1> @llvm.aarch64.sve.ptrue.nxv16i1(i32 31)
42   %ret = tail call <vscale x 16 x i8> @llvm.aarch64.sve.abs.nxv16i8(<vscale x 16 x i8> undef, <vscale x 16 x i1> %pg, <vscale x 16 x i8> %b)
43   ret <vscale x 16 x i8> %ret
46 ; Check movprfx is inserted when predicate is all active, making the passthru dead
47 define <vscale x 16 x i8> @abs_i8_active(<vscale x 16 x i8> %a, <vscale x 16 x i8> %b) #0 {
48 ; CHECK-LABEL: abs_i8_active:
49 ; CHECK:       // %bb.0:
50 ; CHECK-NEXT:    ptrue p0.b
51 ; CHECK-NEXT:    movprfx z0, z1
52 ; CHECK-NEXT:    abs z0.b, p0/m, z1.b
53 ; CHECK-NEXT:    ret
54   %pg = tail call <vscale x 16 x i1> @llvm.aarch64.sve.ptrue.nxv16i1(i32 31)
55   %ret = tail call <vscale x 16 x i8> @llvm.aarch64.sve.abs.nxv16i8(<vscale x 16 x i8> %a, <vscale x 16 x i1> %pg, <vscale x 16 x i8> %b)
56   ret <vscale x 16 x i8> %ret
59 ; Check movprfx is not inserted when predicate is not all active, making the passthru used
60 define <vscale x 16 x i8> @abs_i8_not_active(<vscale x 16 x i8> %a, <vscale x 16 x i8> %b) #0 {
61 ; CHECK-LABEL: abs_i8_not_active:
62 ; CHECK:       // %bb.0:
63 ; CHECK-NEXT:    ptrue p0.d
64 ; CHECK-NEXT:    abs z0.b, p0/m, z1.b
65 ; CHECK-NEXT:    ret
66   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
67   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
68   %ret = tail call <vscale x 16 x i8> @llvm.aarch64.sve.abs.nxv16i8(<vscale x 16 x i8> %a, <vscale x 16 x i1> %pg.to, <vscale x 16 x i8> %b)
69   ret <vscale x 16 x i8> %ret
72 define <vscale x 8 x i16> @abs_i16(<vscale x 8 x i16> %a, <vscale x 8 x i16> %b) #0 {
73 ; CHECK-LABEL: abs_i16:
74 ; CHECK:       // %bb.0:
75 ; CHECK-NEXT:    ptrue p0.h
76 ; CHECK-NEXT:    movprfx z0, z1
77 ; CHECK-NEXT:    abs z0.h, p0/m, z1.h
78 ; CHECK-NEXT:    ret
79   %ret = tail call <vscale x 8 x i16> @llvm.abs.nxv8i16(<vscale x 8 x i16> %b, i1 0)
80   ret <vscale x 8 x i16> %ret
83 define <vscale x 8 x i16> @abs_i16_dupreg(<vscale x 8 x i16> %a) #0 {
84 ; CHECK-LABEL: abs_i16_dupreg:
85 ; CHECK:       // %bb.0:
86 ; CHECK-NEXT:    ptrue p0.h
87 ; CHECK-NEXT:    abs z0.h, p0/m, z0.h
88 ; CHECK-NEXT:    ret
89   %ret = tail call <vscale x 8 x i16> @llvm.abs.nxv8i16(<vscale x 8 x i16> %a, i1 0)
90   ret <vscale x 8 x i16> %ret
93 define <vscale x 8 x i16> @abs_i16_undef(<vscale x 8 x i16> %a, <vscale x 8 x i16> %b) #0 {
94 ; CHECK-LABEL: abs_i16_undef:
95 ; CHECK:       // %bb.0:
96 ; CHECK-NEXT:    ptrue p0.h
97 ; CHECK-NEXT:    movprfx z0, z1
98 ; CHECK-NEXT:    abs z0.h, p0/m, z1.h
99 ; CHECK-NEXT:    ret
100   %pg = tail call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
101   %ret = tail call <vscale x 8 x i16> @llvm.aarch64.sve.abs.nxv8i16(<vscale x 8 x i16> undef, <vscale x 8 x i1> %pg, <vscale x 8 x i16> %b)
102   ret <vscale x 8 x i16> %ret
105 define <vscale x 8 x i16> @abs_i16_active(<vscale x 8 x i16> %a, <vscale x 8 x i16> %b) #0 {
106 ; CHECK-LABEL: abs_i16_active:
107 ; CHECK:       // %bb.0:
108 ; CHECK-NEXT:    ptrue p0.h
109 ; CHECK-NEXT:    movprfx z0, z1
110 ; CHECK-NEXT:    abs z0.h, p0/m, z1.h
111 ; CHECK-NEXT:    ret
112   %pg = tail call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
113   %ret = tail call <vscale x 8 x i16> @llvm.aarch64.sve.abs.nxv8i16(<vscale x 8 x i16> %a, <vscale x 8 x i1> %pg, <vscale x 8 x i16> %b)
114   ret <vscale x 8 x i16> %ret
117 define <vscale x 8 x i16> @abs_i16_not_active(<vscale x 8 x i16> %a, <vscale x 8 x i16> %b) #0 {
118 ; CHECK-LABEL: abs_i16_not_active:
119 ; CHECK:       // %bb.0:
120 ; CHECK-NEXT:    ptrue p0.d
121 ; CHECK-NEXT:    abs z0.h, p0/m, z1.h
122 ; CHECK-NEXT:    ret
123   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
124   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
125   %pg.from = tail call <vscale x 8 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv8i1(<vscale x 16 x i1> %pg.to)
126   %ret = tail call <vscale x 8 x i16> @llvm.aarch64.sve.abs.nxv8i16(<vscale x 8 x i16> %a, <vscale x 8 x i1> %pg.from, <vscale x 8 x i16> %b)
127   ret <vscale x 8 x i16> %ret
130 define <vscale x 4 x i32> @abs_i32(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
131 ; CHECK-LABEL: abs_i32:
132 ; CHECK:       // %bb.0:
133 ; CHECK-NEXT:    ptrue p0.s
134 ; CHECK-NEXT:    movprfx z0, z1
135 ; CHECK-NEXT:    abs z0.s, p0/m, z1.s
136 ; CHECK-NEXT:    ret
137   %ret = tail call <vscale x 4 x i32> @llvm.abs.nxv4i32(<vscale x 4 x i32> %b, i1 0)
138   ret <vscale x 4 x i32> %ret
141 define <vscale x 4 x i32> @abs_i32_dupreg(<vscale x 4 x i32> %a) #0 {
142 ; CHECK-LABEL: abs_i32_dupreg:
143 ; CHECK:       // %bb.0:
144 ; CHECK-NEXT:    ptrue p0.s
145 ; CHECK-NEXT:    abs z0.s, p0/m, z0.s
146 ; CHECK-NEXT:    ret
147   %ret = tail call <vscale x 4 x i32> @llvm.abs.nxv4i32(<vscale x 4 x i32> %a, i1 0)
148   ret <vscale x 4 x i32> %ret
151 define <vscale x 4 x i32> @abs_i32_undef(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
152 ; CHECK-LABEL: abs_i32_undef:
153 ; CHECK:       // %bb.0:
154 ; CHECK-NEXT:    ptrue p0.s
155 ; CHECK-NEXT:    movprfx z0, z1
156 ; CHECK-NEXT:    abs z0.s, p0/m, z1.s
157 ; CHECK-NEXT:    ret
158   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
159   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.abs.nxv4i32(<vscale x 4 x i32> undef, <vscale x 4 x i1> %pg, <vscale x 4 x i32> %b)
160   ret <vscale x 4 x i32> %ret
163 define <vscale x 4 x i32> @abs_i32_active(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
164 ; CHECK-LABEL: abs_i32_active:
165 ; CHECK:       // %bb.0:
166 ; CHECK-NEXT:    ptrue p0.s
167 ; CHECK-NEXT:    movprfx z0, z1
168 ; CHECK-NEXT:    abs z0.s, p0/m, z1.s
169 ; CHECK-NEXT:    ret
170   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
171   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.abs.nxv4i32(<vscale x 4 x i32> %a, <vscale x 4 x i1> %pg, <vscale x 4 x i32> %b)
172   ret <vscale x 4 x i32> %ret
175 define <vscale x 4 x i32> @abs_i32_not_active(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
176 ; CHECK-LABEL: abs_i32_not_active:
177 ; CHECK:       // %bb.0:
178 ; CHECK-NEXT:    ptrue p0.d
179 ; CHECK-NEXT:    abs z0.s, p0/m, z1.s
180 ; CHECK-NEXT:    ret
181   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
182   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
183   %pg.from = tail call <vscale x 4 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv4i1(<vscale x 16 x i1> %pg.to)
184   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.abs.nxv4i32(<vscale x 4 x i32> %a, <vscale x 4 x i1> %pg.from, <vscale x 4 x i32> %b)
185   ret <vscale x 4 x i32> %ret
188 define <vscale x 2 x i64> @abs_i64(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
189 ; CHECK-LABEL: abs_i64:
190 ; CHECK:       // %bb.0:
191 ; CHECK-NEXT:    ptrue p0.d
192 ; CHECK-NEXT:    movprfx z0, z1
193 ; CHECK-NEXT:    abs z0.d, p0/m, z1.d
194 ; CHECK-NEXT:    ret
195   %ret = tail call <vscale x 2 x i64> @llvm.abs.nxv2i64(<vscale x 2 x i64> %b, i1 0)
196   ret <vscale x 2 x i64> %ret
199 define <vscale x 2 x i64> @abs_i64_dupreg(<vscale x 2 x i64> %a) #0 {
200 ; CHECK-LABEL: abs_i64_dupreg:
201 ; CHECK:       // %bb.0:
202 ; CHECK-NEXT:    ptrue p0.d
203 ; CHECK-NEXT:    abs z0.d, p0/m, z0.d
204 ; CHECK-NEXT:    ret
205   %ret = tail call <vscale x 2 x i64> @llvm.abs.nxv2i64(<vscale x 2 x i64> %a, i1 0)
206   ret <vscale x 2 x i64> %ret
209 define <vscale x 2 x i64> @abs_i64_undef(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
210 ; CHECK-LABEL: abs_i64_undef:
211 ; CHECK:       // %bb.0:
212 ; CHECK-NEXT:    ptrue p0.d
213 ; CHECK-NEXT:    movprfx z0, z1
214 ; CHECK-NEXT:    abs z0.d, p0/m, z1.d
215 ; CHECK-NEXT:    ret
216   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
217   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.abs.nxv2i64(<vscale x 2 x i64> undef, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
218   ret <vscale x 2 x i64> %ret
221 define <vscale x 2 x i64> @abs_i64_active(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
222 ; CHECK-LABEL: abs_i64_active:
223 ; CHECK:       // %bb.0:
224 ; CHECK-NEXT:    ptrue p0.d
225 ; CHECK-NEXT:    movprfx z0, z1
226 ; CHECK-NEXT:    abs z0.d, p0/m, z1.d
227 ; CHECK-NEXT:    ret
228   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
229   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.abs.nxv2i64(<vscale x 2 x i64> %a, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
230   ret <vscale x 2 x i64> %ret
233 define <vscale x 2 x i64> @abs_i64_not_active(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b, <vscale x 2 x i1> %pg) #0 {
234 ; CHECK-LABEL: abs_i64_not_active:
235 ; CHECK:       // %bb.0:
236 ; CHECK:         abs z0.d, p0/m, z1.d
237 ; CHECK-NEXT:    ret
238   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.abs.nxv2i64(<vscale x 2 x i64> %a, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
239   ret <vscale x 2 x i64> %ret
243 ; CLS (sve_int_un_pred_arit_1)
246 define <vscale x 16 x i8> @cls_i8_dupreg(<vscale x 16 x i8> %a) #0 {
247 ; CHECK-LABEL: cls_i8_dupreg:
248 ; CHECK:       // %bb.0:
249 ; CHECK-NEXT:    ptrue p0.b
250 ; CHECK-NEXT:    cls z0.b, p0/m, z0.b
251 ; CHECK-NEXT:    ret
252   %pg = tail call <vscale x 16 x i1> @llvm.aarch64.sve.ptrue.nxv16i1(i32 31)
253   %ret = tail call <vscale x 16 x i8> @llvm.aarch64.sve.cls.nxv16i8(<vscale x 16 x i8> undef, <vscale x 16 x i1> %pg, <vscale x 16 x i8> %a)
254   ret <vscale x 16 x i8> %ret
257 define <vscale x 16 x i8> @cls_i8_undef(<vscale x 16 x i8> %a, <vscale x 16 x i8> %b) #0 {
258 ; CHECK-LABEL: cls_i8_undef:
259 ; CHECK:       // %bb.0:
260 ; CHECK-NEXT:    ptrue p0.b
261 ; CHECK-NEXT:    movprfx z0, z1
262 ; CHECK-NEXT:    cls z0.b, p0/m, z1.b
263 ; CHECK-NEXT:    ret
264   %pg = tail call <vscale x 16 x i1> @llvm.aarch64.sve.ptrue.nxv16i1(i32 31)
265   %ret = tail call <vscale x 16 x i8> @llvm.aarch64.sve.cls.nxv16i8(<vscale x 16 x i8> undef, <vscale x 16 x i1> %pg, <vscale x 16 x i8> %b)
266   ret <vscale x 16 x i8> %ret
269 define <vscale x 16 x i8> @cls_i8_active(<vscale x 16 x i8> %a, <vscale x 16 x i8> %b) #0 {
270 ; CHECK-LABEL: cls_i8_active:
271 ; CHECK:       // %bb.0:
272 ; CHECK-NEXT:    ptrue p0.b
273 ; CHECK-NEXT:    movprfx z0, z1
274 ; CHECK-NEXT:    cls z0.b, p0/m, z1.b
275 ; CHECK-NEXT:    ret
276   %pg = tail call <vscale x 16 x i1> @llvm.aarch64.sve.ptrue.nxv16i1(i32 31)
277   %ret = tail call <vscale x 16 x i8> @llvm.aarch64.sve.cls.nxv16i8(<vscale x 16 x i8> %a, <vscale x 16 x i1> %pg, <vscale x 16 x i8> %b)
278   ret <vscale x 16 x i8> %ret
281 define <vscale x 16 x i8> @cls_i8_not_active(<vscale x 16 x i8> %a, <vscale x 16 x i8> %b) #0 {
282 ; CHECK-LABEL: cls_i8_not_active:
283 ; CHECK:       // %bb.0:
284 ; CHECK-NEXT:    ptrue p0.d
285 ; CHECK-NEXT:    cls z0.b, p0/m, z1.b
286 ; CHECK-NEXT:    ret
287   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
288   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
289   %ret = tail call <vscale x 16 x i8> @llvm.aarch64.sve.cls.nxv16i8(<vscale x 16 x i8> %a, <vscale x 16 x i1> %pg.to, <vscale x 16 x i8> %b)
290   ret <vscale x 16 x i8> %ret
293 define <vscale x 8 x i16> @cls_i16_dupreg(<vscale x 8 x i16> %a) #0 {
294 ; CHECK-LABEL: cls_i16_dupreg:
295 ; CHECK:       // %bb.0:
296 ; CHECK-NEXT:    ptrue p0.h
297 ; CHECK-NEXT:    cls z0.h, p0/m, z0.h
298 ; CHECK-NEXT:    ret
299   %pg = tail call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
300   %ret = tail call <vscale x 8 x i16> @llvm.aarch64.sve.cls.nxv8i16(<vscale x 8 x i16> undef, <vscale x 8 x i1> %pg, <vscale x 8 x i16> %a)
301   ret <vscale x 8 x i16> %ret
304 define <vscale x 8 x i16> @cls_i16_undef(<vscale x 8 x i16> %a, <vscale x 8 x i16> %b) #0 {
305 ; CHECK-LABEL: cls_i16_undef:
306 ; CHECK:       // %bb.0:
307 ; CHECK-NEXT:    ptrue p0.h
308 ; CHECK-NEXT:    movprfx z0, z1
309 ; CHECK-NEXT:    cls z0.h, p0/m, z1.h
310 ; CHECK-NEXT:    ret
311   %pg = tail call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
312   %ret = tail call <vscale x 8 x i16> @llvm.aarch64.sve.cls.nxv8i16(<vscale x 8 x i16> undef, <vscale x 8 x i1> %pg, <vscale x 8 x i16> %b)
313   ret <vscale x 8 x i16> %ret
316 define <vscale x 8 x i16> @cls_i16_active(<vscale x 8 x i16> %a, <vscale x 8 x i16> %b) #0 {
317 ; CHECK-LABEL: cls_i16_active:
318 ; CHECK:       // %bb.0:
319 ; CHECK-NEXT:    ptrue p0.h
320 ; CHECK-NEXT:    movprfx z0, z1
321 ; CHECK-NEXT:    cls z0.h, p0/m, z1.h
322 ; CHECK-NEXT:    ret
323   %pg = tail call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
324   %ret = tail call <vscale x 8 x i16> @llvm.aarch64.sve.cls.nxv8i16(<vscale x 8 x i16> %a, <vscale x 8 x i1> %pg, <vscale x 8 x i16> %b)
325   ret <vscale x 8 x i16> %ret
328 define <vscale x 8 x i16> @cls_i16_not_active(<vscale x 8 x i16> %a, <vscale x 8 x i16> %b) #0 {
329 ; CHECK-LABEL: cls_i16_not_active:
330 ; CHECK:       // %bb.0:
331 ; CHECK-NEXT:    ptrue p0.d
332 ; CHECK-NEXT:    cls z0.h, p0/m, z1.h
333 ; CHECK-NEXT:    ret
334   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
335   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
336   %pg.from = tail call <vscale x 8 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv8i1(<vscale x 16 x i1> %pg.to)
337   %ret = tail call <vscale x 8 x i16> @llvm.aarch64.sve.cls.nxv8i16(<vscale x 8 x i16> %a, <vscale x 8 x i1> %pg.from, <vscale x 8 x i16> %b)
338   ret <vscale x 8 x i16> %ret
341 define <vscale x 4 x i32> @cls_i32_dupreg(<vscale x 4 x i32> %a) #0 {
342 ; CHECK-LABEL: cls_i32_dupreg:
343 ; CHECK:       // %bb.0:
344 ; CHECK-NEXT:    ptrue p0.s
345 ; CHECK-NEXT:    cls z0.s, p0/m, z0.s
346 ; CHECK-NEXT:    ret
347   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
348   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.cls.nxv4i32(<vscale x 4 x i32> undef, <vscale x 4 x i1> %pg, <vscale x 4 x i32> %a)
349   ret <vscale x 4 x i32> %ret
352 define <vscale x 4 x i32> @cls_i32_undef(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
353 ; CHECK-LABEL: cls_i32_undef:
354 ; CHECK:       // %bb.0:
355 ; CHECK-NEXT:    ptrue p0.s
356 ; CHECK-NEXT:    movprfx z0, z1
357 ; CHECK-NEXT:    cls z0.s, p0/m, z1.s
358 ; CHECK-NEXT:    ret
359   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
360   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.cls.nxv4i32(<vscale x 4 x i32> undef, <vscale x 4 x i1> %pg, <vscale x 4 x i32> %b)
361   ret <vscale x 4 x i32> %ret
364 define <vscale x 4 x i32> @cls_i32_active(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
365 ; CHECK-LABEL: cls_i32_active:
366 ; CHECK:       // %bb.0:
367 ; CHECK-NEXT:    ptrue p0.s
368 ; CHECK-NEXT:    movprfx z0, z1
369 ; CHECK-NEXT:    cls z0.s, p0/m, z1.s
370 ; CHECK-NEXT:    ret
371   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
372   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.cls.nxv4i32(<vscale x 4 x i32> %a, <vscale x 4 x i1> %pg, <vscale x 4 x i32> %b)
373   ret <vscale x 4 x i32> %ret
376 define <vscale x 4 x i32> @cls_i32_not_active(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
377 ; CHECK-LABEL: cls_i32_not_active:
378 ; CHECK:       // %bb.0:
379 ; CHECK-NEXT:    ptrue p0.d
380 ; CHECK-NEXT:    cls z0.s, p0/m, z1.s
381 ; CHECK-NEXT:    ret
382   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
383   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
384   %pg.from = tail call <vscale x 4 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv4i1(<vscale x 16 x i1> %pg.to)
385   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.cls.nxv4i32(<vscale x 4 x i32> %a, <vscale x 4 x i1> %pg.from, <vscale x 4 x i32> %b)
386   ret <vscale x 4 x i32> %ret
389 define <vscale x 2 x i64> @cls_i64_dupreg(<vscale x 2 x i64> %a) #0 {
390 ; CHECK-LABEL: cls_i64_dupreg:
391 ; CHECK:       // %bb.0:
392 ; CHECK-NEXT:    ptrue p0.d
393 ; CHECK-NEXT:    cls z0.d, p0/m, z0.d
394 ; CHECK-NEXT:    ret
395   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
396   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.cls.nxv2i64(<vscale x 2 x i64> undef, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %a)
397   ret <vscale x 2 x i64> %ret
400 define <vscale x 2 x i64> @cls_i64_undef(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
401 ; CHECK-LABEL: cls_i64_undef:
402 ; CHECK:       // %bb.0:
403 ; CHECK-NEXT:    ptrue p0.d
404 ; CHECK-NEXT:    movprfx z0, z1
405 ; CHECK-NEXT:    cls z0.d, p0/m, z1.d
406 ; CHECK-NEXT:    ret
407   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
408   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.cls.nxv2i64(<vscale x 2 x i64> undef, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
409   ret <vscale x 2 x i64> %ret
412 define <vscale x 2 x i64> @cls_i64_active(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
413 ; CHECK-LABEL: cls_i64_active:
414 ; CHECK:       // %bb.0:
415 ; CHECK-NEXT:    ptrue p0.d
416 ; CHECK-NEXT:    movprfx z0, z1
417 ; CHECK-NEXT:    cls z0.d, p0/m, z1.d
418 ; CHECK-NEXT:    ret
419   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
420   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.cls.nxv2i64(<vscale x 2 x i64> %a, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
421   ret <vscale x 2 x i64> %ret
424 define <vscale x 2 x i64> @cls_i64_not_active(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b, <vscale x 2 x i1> %pg) #0 {
425 ; CHECK-LABEL: cls_i64_not_active:
426 ; CHECK:       // %bb.0:
427 ; CHECK:         cls z0.d, p0/m, z1.d
428 ; CHECK-NEXT:    ret
429   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.cls.nxv2i64(<vscale x 2 x i64> %a, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
430   ret <vscale x 2 x i64> %ret
434 ; FABS (sve_int_un_pred_arit_1_fp)
437 define <vscale x 8 x half> @fabs_f16(<vscale x 8 x half> %a, <vscale x 8 x half> %b) #0 {
438 ; CHECK-LABEL: fabs_f16:
439 ; CHECK:       // %bb.0:
440 ; CHECK-NEXT:    ptrue p0.h
441 ; CHECK-NEXT:    movprfx z0, z1
442 ; CHECK-NEXT:    fabs z0.h, p0/m, z1.h
443 ; CHECK-NEXT:    ret
444   %ret = tail call <vscale x 8 x half> @llvm.fabs.nxv8f16(<vscale x 8 x half> %b)
445   ret <vscale x 8 x half> %ret
448 define <vscale x 8 x half> @fabs_f16_dupreg(<vscale x 8 x half> %a) #0 {
449 ; CHECK-LABEL: fabs_f16_dupreg:
450 ; CHECK:       // %bb.0:
451 ; CHECK-NEXT:    ptrue p0.h
452 ; CHECK-NEXT:    fabs z0.h, p0/m, z0.h
453 ; CHECK-NEXT:    ret
454   %ret = tail call <vscale x 8 x half> @llvm.fabs.nxv8f16(<vscale x 8 x half> %a)
455   ret <vscale x 8 x half> %ret
458 define <vscale x 8 x half> @fabs_f16_undef(<vscale x 8 x half> %a, <vscale x 8 x half> %b) #0 {
459 ; CHECK-LABEL: fabs_f16_undef:
460 ; CHECK:       // %bb.0:
461 ; CHECK-NEXT:    ptrue p0.h
462 ; CHECK-NEXT:    movprfx z0, z1
463 ; CHECK-NEXT:    fabs z0.h, p0/m, z1.h
464 ; CHECK-NEXT:    ret
465   %pg = tail call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
466   %ret = tail call <vscale x 8 x half> @llvm.aarch64.sve.fabs.nxv8f16(<vscale x 8 x half> undef, <vscale x 8 x i1> %pg, <vscale x 8 x half> %b)
467   ret <vscale x 8 x half> %ret
470 define <vscale x 8 x half> @fabs_f16_active(<vscale x 8 x half> %a, <vscale x 8 x half> %b) #0 {
471 ; CHECK-LABEL: fabs_f16_active:
472 ; CHECK:       // %bb.0:
473 ; CHECK-NEXT:    ptrue p0.h
474 ; CHECK-NEXT:    movprfx z0, z1
475 ; CHECK-NEXT:    fabs z0.h, p0/m, z1.h
476 ; CHECK-NEXT:    ret
477   %pg = tail call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
478   %ret = tail call <vscale x 8 x half> @llvm.aarch64.sve.fabs.nxv8f16(<vscale x 8 x half> %a, <vscale x 8 x i1> %pg, <vscale x 8 x half> %b)
479   ret <vscale x 8 x half> %ret
482 define <vscale x 8 x half> @fabs_f16_not_active(<vscale x 8 x half> %a, <vscale x 8 x half> %b) #0 {
483 ; CHECK-LABEL: fabs_f16_not_active:
484 ; CHECK:       // %bb.0:
485 ; CHECK-NEXT:    ptrue p0.d
486 ; CHECK-NEXT:    fabs z0.h, p0/m, z1.h
487 ; CHECK-NEXT:    ret
488   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
489   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
490   %pg.from = tail call <vscale x 8 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv8i1(<vscale x 16 x i1> %pg.to)
491   %ret = tail call <vscale x 8 x half> @llvm.aarch64.sve.fabs.nxv8f16(<vscale x 8 x half> %a, <vscale x 8 x i1> %pg.from, <vscale x 8 x half> %b)
492   ret <vscale x 8 x half> %ret
495 define <vscale x 4 x float> @fabs_f32(<vscale x 4 x float> %a, <vscale x 4 x float> %b) #0 {
496 ; CHECK-LABEL: fabs_f32:
497 ; CHECK:       // %bb.0:
498 ; CHECK-NEXT:    ptrue p0.s
499 ; CHECK-NEXT:    movprfx z0, z1
500 ; CHECK-NEXT:    fabs z0.s, p0/m, z1.s
501 ; CHECK-NEXT:    ret
502   %ret = tail call <vscale x 4 x float> @llvm.fabs.nxv4f32(<vscale x 4 x float> %b)
503   ret <vscale x 4 x float> %ret
506 define <vscale x 4 x float> @fabs_f32_dupreg(<vscale x 4 x float> %a) #0 {
507 ; CHECK-LABEL: fabs_f32_dupreg:
508 ; CHECK:       // %bb.0:
509 ; CHECK-NEXT:    ptrue p0.s
510 ; CHECK-NEXT:    fabs z0.s, p0/m, z0.s
511 ; CHECK-NEXT:    ret
512   %ret = tail call <vscale x 4 x float> @llvm.fabs.nxv4f32(<vscale x 4 x float> %a)
513   ret <vscale x 4 x float> %ret
516 define <vscale x 4 x float> @fabs_f32_undef(<vscale x 4 x float> %a, <vscale x 4 x float> %b) #0 {
517 ; CHECK-LABEL: fabs_f32_undef:
518 ; CHECK:       // %bb.0:
519 ; CHECK-NEXT:    ptrue p0.s
520 ; CHECK-NEXT:    movprfx z0, z1
521 ; CHECK-NEXT:    fabs z0.s, p0/m, z1.s
522 ; CHECK-NEXT:    ret
523   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
524   %ret = tail call <vscale x 4 x float> @llvm.aarch64.sve.fabs.nxv4f32(<vscale x 4 x float> undef, <vscale x 4 x i1> %pg, <vscale x 4 x float> %b)
525   ret <vscale x 4 x float> %ret
528 define <vscale x 4 x float> @fabs_f32_active(<vscale x 4 x float> %a, <vscale x 4 x float> %b) #0 {
529 ; CHECK-LABEL: fabs_f32_active:
530 ; CHECK:       // %bb.0:
531 ; CHECK-NEXT:    ptrue p0.s
532 ; CHECK-NEXT:    movprfx z0, z1
533 ; CHECK-NEXT:    fabs z0.s, p0/m, z1.s
534 ; CHECK-NEXT:    ret
535   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
536   %ret = tail call <vscale x 4 x float> @llvm.aarch64.sve.fabs.nxv4f32(<vscale x 4 x float> %a, <vscale x 4 x i1> %pg, <vscale x 4 x float> %b)
537   ret <vscale x 4 x float> %ret
540 define <vscale x 4 x float> @fabs_f32_not_active(<vscale x 4 x float> %a, <vscale x 4 x float> %b) #0 {
541 ; CHECK-LABEL: fabs_f32_not_active:
542 ; CHECK:       // %bb.0:
543 ; CHECK-NEXT:    ptrue p0.d
544 ; CHECK-NEXT:    fabs z0.s, p0/m, z1.s
545 ; CHECK-NEXT:    ret
546   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
547   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
548   %pg.from = tail call <vscale x 4 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv4i1(<vscale x 16 x i1> %pg.to)
549   %ret = tail call <vscale x 4 x float> @llvm.aarch64.sve.fabs.nxv4f32(<vscale x 4 x float> %a, <vscale x 4 x i1> %pg.from, <vscale x 4 x float> %b)
550   ret <vscale x 4 x float> %ret
553 define <vscale x 2 x double> @fabs_f64(<vscale x 2 x double> %a, <vscale x 2 x double> %b) #0 {
554 ; CHECK-LABEL: fabs_f64:
555 ; CHECK:       // %bb.0:
556 ; CHECK-NEXT:    ptrue p0.d
557 ; CHECK-NEXT:    movprfx z0, z1
558 ; CHECK-NEXT:    fabs z0.d, p0/m, z1.d
559 ; CHECK-NEXT:    ret
560   %ret = tail call <vscale x 2 x double> @llvm.fabs.nxv2f64(<vscale x 2 x double> %b)
561   ret <vscale x 2 x double> %ret
564 define <vscale x 2 x double> @fabs_f64_dupreg(<vscale x 2 x double> %a) #0 {
565 ; CHECK-LABEL: fabs_f64_dupreg:
566 ; CHECK:       // %bb.0:
567 ; CHECK-NEXT:    ptrue p0.d
568 ; CHECK-NEXT:    fabs z0.d, p0/m, z0.d
569 ; CHECK-NEXT:    ret
570   %ret = tail call <vscale x 2 x double> @llvm.fabs.nxv2f64(<vscale x 2 x double> %a)
571   ret <vscale x 2 x double> %ret
574 define <vscale x 2 x double> @fabs_f64_undef(<vscale x 2 x double> %a, <vscale x 2 x double> %b) #0 {
575 ; CHECK-LABEL: fabs_f64_undef:
576 ; CHECK:       // %bb.0:
577 ; CHECK-NEXT:    ptrue p0.d
578 ; CHECK-NEXT:    movprfx z0, z1
579 ; CHECK-NEXT:    fabs z0.d, p0/m, z1.d
580 ; CHECK-NEXT:    ret
581   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
582   %ret = tail call <vscale x 2 x double> @llvm.aarch64.sve.fabs.nxv2f64(<vscale x 2 x double> undef, <vscale x 2 x i1> %pg, <vscale x 2 x double> %b)
583   ret <vscale x 2 x double> %ret
586 define <vscale x 2 x double> @fabs_f64_active(<vscale x 2 x double> %a, <vscale x 2 x double> %b) #0 {
587 ; CHECK-LABEL: fabs_f64_active:
588 ; CHECK:       // %bb.0:
589 ; CHECK-NEXT:    ptrue p0.d
590 ; CHECK-NEXT:    movprfx z0, z1
591 ; CHECK-NEXT:    fabs z0.d, p0/m, z1.d
592 ; CHECK-NEXT:    ret
593   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
594   %ret = tail call <vscale x 2 x double> @llvm.aarch64.sve.fabs.nxv2f64(<vscale x 2 x double> %a, <vscale x 2 x i1> %pg, <vscale x 2 x double> %b)
595   ret <vscale x 2 x double> %ret
598 define <vscale x 2 x double> @fabs_f64_not_active(<vscale x 2 x double> %a, <vscale x 2 x double> %b, <vscale x 2 x i1> %pg) #0 {
599 ; CHECK-LABEL: fabs_f64_not_active:
600 ; CHECK:       // %bb.0:
601 ; CHECK:         fabs z0.d, p0/m, z1.d
602 ; CHECK-NEXT:    ret
603   %ret = tail call <vscale x 2 x double> @llvm.aarch64.sve.fabs.nxv2f64(<vscale x 2 x double> %a, <vscale x 2 x i1> %pg, <vscale x 2 x double> %b)
604   ret <vscale x 2 x double> %ret
608 ; SXTB (sve_int_un_pred_arit_0_h)
611 define <vscale x 8 x i16> @sxtb_i16(<vscale x 8 x i8> %a, <vscale x 8 x i8> %b) #0 {
612 ; CHECK-LABEL: sxtb_i16:
613 ; CHECK:       // %bb.0:
614 ; CHECK-NEXT:    ptrue p0.h
615 ; CHECK-NEXT:    movprfx z0, z1
616 ; CHECK-NEXT:    sxtb z0.h, p0/m, z1.h
617 ; CHECK-NEXT:    ret
618   %ret = sext <vscale x 8 x i8> %b to <vscale x 8 x i16>
619   ret <vscale x 8 x i16> %ret
622 define <vscale x 8 x i16> @sxtb_i16_dupreg(<vscale x 8 x i8> %a) #0 {
623 ; CHECK-LABEL: sxtb_i16_dupreg:
624 ; CHECK:       // %bb.0:
625 ; CHECK-NEXT:    ptrue p0.h
626 ; CHECK-NEXT:    sxtb z0.h, p0/m, z0.h
627 ; CHECK-NEXT:    ret
628   %ret = sext <vscale x 8 x i8> %a to <vscale x 8 x i16>
629   ret <vscale x 8 x i16> %ret
632 define <vscale x 8 x i16> @sxtb_i16_undef(<vscale x 8 x i16> %a, <vscale x 8 x i16> %b) #0 {
633 ; CHECK-LABEL: sxtb_i16_undef:
634 ; CHECK:       // %bb.0:
635 ; CHECK-NEXT:    ptrue p0.h
636 ; CHECK-NEXT:    movprfx z0, z1
637 ; CHECK-NEXT:    sxtb z0.h, p0/m, z1.h
638 ; CHECK-NEXT:    ret
639   %pg = tail call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
640   %ret = tail call <vscale x 8 x i16> @llvm.aarch64.sve.sxtb.nxv8i16(<vscale x 8 x i16> undef, <vscale x 8 x i1> %pg, <vscale x 8 x i16> %b)
641   ret <vscale x 8 x i16> %ret
644 define <vscale x 8 x i16> @sxtb_i16_active(<vscale x 8 x i16> %a, <vscale x 8 x i16> %b) #0 {
645 ; CHECK-LABEL: sxtb_i16_active:
646 ; CHECK:       // %bb.0:
647 ; CHECK-NEXT:    ptrue p0.h
648 ; CHECK-NEXT:    movprfx z0, z1
649 ; CHECK-NEXT:    sxtb z0.h, p0/m, z1.h
650 ; CHECK-NEXT:    ret
651   %pg = tail call <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32 31)
652   %ret = tail call <vscale x 8 x i16> @llvm.aarch64.sve.sxtb.nxv8i16(<vscale x 8 x i16> %a, <vscale x 8 x i1> %pg, <vscale x 8 x i16> %b)
653   ret <vscale x 8 x i16> %ret
656 define <vscale x 8 x i16> @sxtb_i16_not_active(<vscale x 8 x i16> %a, <vscale x 8 x i16> %b) #0 {
657 ; CHECK-LABEL: sxtb_i16_not_active:
658 ; CHECK:       // %bb.0:
659 ; CHECK-NEXT:    ptrue p0.d
660 ; CHECK-NEXT:    sxtb z0.h, p0/m, z1.h
661 ; CHECK-NEXT:    ret
662   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
663   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
664   %pg.from = tail call <vscale x 8 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv8i1(<vscale x 16 x i1> %pg.to)
665   %ret = tail call <vscale x 8 x i16> @llvm.aarch64.sve.sxtb.nxv8i16(<vscale x 8 x i16> %a, <vscale x 8 x i1> %pg.from, <vscale x 8 x i16> %b)
666   ret <vscale x 8 x i16> %ret
669 define <vscale x 4 x i32> @sxtb_i32(<vscale x 4 x i8> %a, <vscale x 4 x i8> %b) #0 {
670 ; CHECK-LABEL: sxtb_i32:
671 ; CHECK:       // %bb.0:
672 ; CHECK-NEXT:    ptrue p0.s
673 ; CHECK-NEXT:    movprfx z0, z1
674 ; CHECK-NEXT:    sxtb z0.s, p0/m, z1.s
675 ; CHECK-NEXT:    ret
676   %ret = sext <vscale x 4 x i8> %b to <vscale x 4 x i32>
677   ret <vscale x 4 x i32> %ret
680 define <vscale x 4 x i32> @sxtb_i32_dupreg(<vscale x 4 x i8> %a) #0 {
681 ; CHECK-LABEL: sxtb_i32_dupreg:
682 ; CHECK:       // %bb.0:
683 ; CHECK-NEXT:    ptrue p0.s
684 ; CHECK-NEXT:    sxtb z0.s, p0/m, z0.s
685 ; CHECK-NEXT:    ret
686   %ret = sext <vscale x 4 x i8> %a to <vscale x 4 x i32>
687   ret <vscale x 4 x i32> %ret
690 define <vscale x 4 x i32> @sxtb_i32_undef(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
691 ; CHECK-LABEL: sxtb_i32_undef:
692 ; CHECK:       // %bb.0:
693 ; CHECK-NEXT:    ptrue p0.s
694 ; CHECK-NEXT:    movprfx z0, z1
695 ; CHECK-NEXT:    sxtb z0.s, p0/m, z1.s
696 ; CHECK-NEXT:    ret
697   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
698   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.sxtb.nxv4i32(<vscale x 4 x i32> undef, <vscale x 4 x i1> %pg, <vscale x 4 x i32> %b)
699   ret <vscale x 4 x i32> %ret
702 define <vscale x 4 x i32> @sxtb_i32_active(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
703 ; CHECK-LABEL: sxtb_i32_active:
704 ; CHECK:       // %bb.0:
705 ; CHECK-NEXT:    ptrue p0.s
706 ; CHECK-NEXT:    movprfx z0, z1
707 ; CHECK-NEXT:    sxtb z0.s, p0/m, z1.s
708 ; CHECK-NEXT:    ret
709   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
710   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.sxtb.nxv4i32(<vscale x 4 x i32> %a, <vscale x 4 x i1> %pg, <vscale x 4 x i32> %b)
711   ret <vscale x 4 x i32> %ret
714 define <vscale x 4 x i32> @sxtb_i32_not_active(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
715 ; CHECK-LABEL: sxtb_i32_not_active:
716 ; CHECK:       // %bb.0:
717 ; CHECK-NEXT:    ptrue p0.d
718 ; CHECK-NEXT:    sxtb z0.s, p0/m, z1.s
719 ; CHECK-NEXT:    ret
720   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
721   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
722   %pg.from = tail call <vscale x 4 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv4i1(<vscale x 16 x i1> %pg.to)
723   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.sxtb.nxv4i32(<vscale x 4 x i32> %a, <vscale x 4 x i1> %pg.from, <vscale x 4 x i32> %b)
724   ret <vscale x 4 x i32> %ret
727 define <vscale x 2 x i64> @sxtb_i64(<vscale x 2 x i8> %a, <vscale x 2 x i8> %b) #0 {
728 ; CHECK-LABEL: sxtb_i64:
729 ; CHECK:       // %bb.0:
730 ; CHECK-NEXT:    ptrue p0.d
731 ; CHECK-NEXT:    movprfx z0, z1
732 ; CHECK-NEXT:    sxtb z0.d, p0/m, z1.d
733 ; CHECK-NEXT:    ret
734   %ret = sext <vscale x 2 x i8> %b to <vscale x 2 x i64>
735   ret <vscale x 2 x i64> %ret
738 define <vscale x 2 x i64> @sxtb_i64_dupreg(<vscale x 2 x i8> %a) #0 {
739 ; CHECK-LABEL: sxtb_i64_dupreg:
740 ; CHECK:       // %bb.0:
741 ; CHECK-NEXT:    ptrue p0.d
742 ; CHECK-NEXT:    sxtb z0.d, p0/m, z0.d
743 ; CHECK-NEXT:    ret
744   %ret = sext <vscale x 2 x i8> %a to <vscale x 2 x i64>
745   ret <vscale x 2 x i64> %ret
748 define <vscale x 2 x i64> @sxtb_i64_undef(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
749 ; CHECK-LABEL: sxtb_i64_undef:
750 ; CHECK:       // %bb.0:
751 ; CHECK-NEXT:    ptrue p0.d
752 ; CHECK-NEXT:    movprfx z0, z1
753 ; CHECK-NEXT:    sxtb z0.d, p0/m, z1.d
754 ; CHECK-NEXT:    ret
755   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
756   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.sxtb.nxv2i64(<vscale x 2 x i64> undef, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
757   ret <vscale x 2 x i64> %ret
760 define <vscale x 2 x i64> @sxtb_i64_active(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
761 ; CHECK-LABEL: sxtb_i64_active:
762 ; CHECK:       // %bb.0:
763 ; CHECK-NEXT:    ptrue p0.d
764 ; CHECK-NEXT:    movprfx z0, z1
765 ; CHECK-NEXT:    sxtb z0.d, p0/m, z1.d
766 ; CHECK-NEXT:    ret
767   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
768   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.sxtb.nxv2i64(<vscale x 2 x i64> %a, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
769   ret <vscale x 2 x i64> %ret
772 define <vscale x 2 x i64> @sxtb_i64_not_active(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b, <vscale x 2 x i1> %pg) #0 {
773 ; CHECK-LABEL: sxtb_i64_not_active:
774 ; CHECK:       // %bb.0:
775 ; CHECK:         sxtb z0.d, p0/m, z1.d
776 ; CHECK-NEXT:    ret
777   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.sxtb.nxv2i64(<vscale x 2 x i64> %a, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
778   ret <vscale x 2 x i64> %ret
782 ; SXTH (sve_int_un_pred_arit_0_w)
785 define <vscale x 4 x i32> @sxth_i32(<vscale x 4 x i16> %a, <vscale x 4 x i16> %b) #0 {
786 ; CHECK-LABEL: sxth_i32:
787 ; CHECK:       // %bb.0:
788 ; CHECK-NEXT:    ptrue p0.s
789 ; CHECK-NEXT:    movprfx z0, z1
790 ; CHECK-NEXT:    sxth z0.s, p0/m, z1.s
791 ; CHECK-NEXT:    ret
792   %ret = sext <vscale x 4 x i16> %b to <vscale x 4 x i32>
793   ret <vscale x 4 x i32> %ret
796 define <vscale x 4 x i32> @sxth_i32_dupreg(<vscale x 4 x i16> %a) #0 {
797 ; CHECK-LABEL: sxth_i32_dupreg:
798 ; CHECK:       // %bb.0:
799 ; CHECK-NEXT:    ptrue p0.s
800 ; CHECK-NEXT:    sxth z0.s, p0/m, z0.s
801 ; CHECK-NEXT:    ret
802   %ret = sext <vscale x 4 x i16> %a to <vscale x 4 x i32>
803   ret <vscale x 4 x i32> %ret
806 define <vscale x 4 x i32> @sxth_i32_undef(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
807 ; CHECK-LABEL: sxth_i32_undef:
808 ; CHECK:       // %bb.0:
809 ; CHECK-NEXT:    ptrue p0.s
810 ; CHECK-NEXT:    movprfx z0, z1
811 ; CHECK-NEXT:    sxth z0.s, p0/m, z1.s
812 ; CHECK-NEXT:    ret
813   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
814   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.sxth.nxv4i32(<vscale x 4 x i32> undef, <vscale x 4 x i1> %pg, <vscale x 4 x i32> %b)
815   ret <vscale x 4 x i32> %ret
818 define <vscale x 4 x i32> @sxth_i32_active(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
819 ; CHECK-LABEL: sxth_i32_active:
820 ; CHECK:       // %bb.0:
821 ; CHECK-NEXT:    ptrue p0.s
822 ; CHECK-NEXT:    movprfx z0, z1
823 ; CHECK-NEXT:    sxth z0.s, p0/m, z1.s
824 ; CHECK-NEXT:    ret
825   %pg = tail call <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32 31)
826   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.sxth.nxv4i32(<vscale x 4 x i32> %a, <vscale x 4 x i1> %pg, <vscale x 4 x i32> %b)
827   ret <vscale x 4 x i32> %ret
830 define <vscale x 4 x i32> @sxth_i32_not_active(<vscale x 4 x i32> %a, <vscale x 4 x i32> %b) #0 {
831 ; CHECK-LABEL: sxth_i32_not_active:
832 ; CHECK:       // %bb.0:
833 ; CHECK-NEXT:    ptrue p0.d
834 ; CHECK-NEXT:    sxth z0.s, p0/m, z1.s
835 ; CHECK-NEXT:    ret
836   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
837   %pg.to = tail call <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1> %pg)
838   %pg.from = tail call <vscale x 4 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv4i1(<vscale x 16 x i1> %pg.to)
839   %ret = tail call <vscale x 4 x i32> @llvm.aarch64.sve.sxth.nxv4i32(<vscale x 4 x i32> %a, <vscale x 4 x i1> %pg.from, <vscale x 4 x i32> %b)
840   ret <vscale x 4 x i32> %ret
843 define <vscale x 2 x i64> @sxth_i64(<vscale x 2 x i16> %a, <vscale x 2 x i16> %b) #0 {
844 ; CHECK-LABEL: sxth_i64:
845 ; CHECK:       // %bb.0:
846 ; CHECK-NEXT:    ptrue p0.d
847 ; CHECK-NEXT:    movprfx z0, z1
848 ; CHECK-NEXT:    sxth z0.d, p0/m, z1.d
849 ; CHECK-NEXT:    ret
850   %ret = sext <vscale x 2 x i16> %b to <vscale x 2 x i64>
851   ret <vscale x 2 x i64> %ret
854 define <vscale x 2 x i64> @sxth_i64_dupreg(<vscale x 2 x i16> %a) #0 {
855 ; CHECK-LABEL: sxth_i64_dupreg:
856 ; CHECK:       // %bb.0:
857 ; CHECK-NEXT:    ptrue p0.d
858 ; CHECK-NEXT:    sxth z0.d, p0/m, z0.d
859 ; CHECK-NEXT:    ret
860   %ret = sext <vscale x 2 x i16> %a to <vscale x 2 x i64>
861   ret <vscale x 2 x i64> %ret
864 define <vscale x 2 x i64> @sxth_i64_undef(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
865 ; CHECK-LABEL: sxth_i64_undef:
866 ; CHECK:       // %bb.0:
867 ; CHECK-NEXT:    ptrue p0.d
868 ; CHECK-NEXT:    movprfx z0, z1
869 ; CHECK-NEXT:    sxth z0.d, p0/m, z1.d
870 ; CHECK-NEXT:    ret
871   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
872   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.sxth.nxv2i64(<vscale x 2 x i64> undef, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
873   ret <vscale x 2 x i64> %ret
876 define <vscale x 2 x i64> @sxth_i64_active(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
877 ; CHECK-LABEL: sxth_i64_active:
878 ; CHECK:       // %bb.0:
879 ; CHECK-NEXT:    ptrue p0.d
880 ; CHECK-NEXT:    movprfx z0, z1
881 ; CHECK-NEXT:    sxth z0.d, p0/m, z1.d
882 ; CHECK-NEXT:    ret
883   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
884   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.sxth.nxv2i64(<vscale x 2 x i64> %a, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
885   ret <vscale x 2 x i64> %ret
888 define <vscale x 2 x i64> @sxth_i64_not_active(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b, <vscale x 2 x i1> %pg) #0 {
889 ; CHECK-LABEL: sxth_i64_not_active:
890 ; CHECK:       // %bb.0:
891 ; CHECK:         sxth z0.d, p0/m, z1.d
892 ; CHECK-NEXT:    ret
893   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.sxth.nxv2i64(<vscale x 2 x i64> %a, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
894   ret <vscale x 2 x i64> %ret
898 ; SXTW (sve_int_un_pred_arit_0_d)
901 define <vscale x 2 x i64> @sxtw_i64(<vscale x 2 x i32> %a, <vscale x 2 x i32> %b) #0 {
902 ; CHECK-LABEL: sxtw_i64:
903 ; CHECK:       // %bb.0:
904 ; CHECK-NEXT:    ptrue p0.d
905 ; CHECK-NEXT:    movprfx z0, z1
906 ; CHECK-NEXT:    sxtw z0.d, p0/m, z1.d
907 ; CHECK-NEXT:    ret
908   %ret = sext <vscale x 2 x i32> %b to <vscale x 2 x i64>
909   ret <vscale x 2 x i64> %ret
912 define <vscale x 2 x i64> @sxtw_i64_dupreg(<vscale x 2 x i32> %a) #0 {
913 ; CHECK-LABEL: sxtw_i64_dupreg:
914 ; CHECK:       // %bb.0:
915 ; CHECK-NEXT:    ptrue p0.d
916 ; CHECK-NEXT:    sxtw z0.d, p0/m, z0.d
917 ; CHECK-NEXT:    ret
918   %ret = sext <vscale x 2 x i32> %a to <vscale x 2 x i64>
919   ret <vscale x 2 x i64> %ret
922 define <vscale x 2 x i64> @sxtw_i64_undef(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
923 ; CHECK-LABEL: sxtw_i64_undef:
924 ; CHECK:       // %bb.0:
925 ; CHECK-NEXT:    ptrue p0.d
926 ; CHECK-NEXT:    movprfx z0, z1
927 ; CHECK-NEXT:    sxtw z0.d, p0/m, z1.d
928 ; CHECK-NEXT:    ret
929   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
930   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.sxtw.nxv2i64(<vscale x 2 x i64> undef, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
931   ret <vscale x 2 x i64> %ret
934 define <vscale x 2 x i64> @sxtw_i64_active(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b) #0 {
935 ; CHECK-LABEL: sxtw_i64_active:
936 ; CHECK:       // %bb.0:
937 ; CHECK-NEXT:    ptrue p0.d
938 ; CHECK-NEXT:    movprfx z0, z1
939 ; CHECK-NEXT:    sxtw z0.d, p0/m, z1.d
940 ; CHECK-NEXT:    ret
941   %pg = tail call <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32 31)
942   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.sxtw.nxv2i64(<vscale x 2 x i64> %a, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
943   ret <vscale x 2 x i64> %ret
946 define <vscale x 2 x i64> @sxtw_i64_not_active(<vscale x 2 x i64> %a, <vscale x 2 x i64> %b, <vscale x 2 x i1> %pg) #0 {
947 ; CHECK-LABEL: sxtw_i64_not_active:
948 ; CHECK:       // %bb.0:
949 ; CHECK:         sxtw z0.d, p0/m, z1.d
950 ; CHECK-NEXT:    ret
951   %ret = tail call <vscale x 2 x i64> @llvm.aarch64.sve.sxtw.nxv2i64(<vscale x 2 x i64> %a, <vscale x 2 x i1> %pg, <vscale x 2 x i64> %b)
952   ret <vscale x 2 x i64> %ret
955 declare <vscale x 16 x i1> @llvm.aarch64.sve.ptrue.nxv16i1(i32)
956 declare <vscale x 8 x i1> @llvm.aarch64.sve.ptrue.nxv8i1(i32)
957 declare <vscale x 4 x i1> @llvm.aarch64.sve.ptrue.nxv4i1(i32)
958 declare <vscale x 2 x i1> @llvm.aarch64.sve.ptrue.nxv2i1(i32)
960 declare <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv8i1(<vscale x 8 x i1>)
961 declare <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv4i1(<vscale x 4 x i1>)
962 declare <vscale x 16 x i1> @llvm.aarch64.sve.convert.to.svbool.nxv2i1(<vscale x 2 x i1>)
964 declare <vscale x 8 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv8i1(<vscale x 16 x i1>)
965 declare <vscale x 4 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv4i1(<vscale x 16 x i1>)
966 declare <vscale x 2 x i1> @llvm.aarch64.sve.convert.from.svbool.nxv2i1(<vscale x 16 x i1>)
968 declare <vscale x 16 x i8> @llvm.aarch64.sve.abs.nxv16i8(<vscale x 16 x i8>, <vscale x 16 x i1>, <vscale x 16 x i8>)
969 declare <vscale x 8 x i16> @llvm.aarch64.sve.abs.nxv8i16(<vscale x 8 x i16>, <vscale x 8 x i1>, <vscale x 8 x i16>)
970 declare <vscale x 4 x i32> @llvm.aarch64.sve.abs.nxv4i32(<vscale x 4 x i32>, <vscale x 4 x i1>, <vscale x 4 x i32>)
971 declare <vscale x 2 x i64> @llvm.aarch64.sve.abs.nxv2i64(<vscale x 2 x i64>, <vscale x 2 x i1>, <vscale x 2 x i64>)
973 declare <vscale x 16 x i8> @llvm.abs.nxv16i8(<vscale x 16 x i8>, i1)
974 declare <vscale x 8 x i16> @llvm.abs.nxv8i16(<vscale x 8 x i16>, i1)
975 declare <vscale x 4 x i32> @llvm.abs.nxv4i32(<vscale x 4 x i32>, i1)
976 declare <vscale x 2 x i64> @llvm.abs.nxv2i64(<vscale x 2 x i64>, i1)
978 declare <vscale x 16 x i8> @llvm.aarch64.sve.cls.nxv16i8(<vscale x 16 x i8>, <vscale x 16 x i1>, <vscale x 16 x i8>)
979 declare <vscale x 8 x i16> @llvm.aarch64.sve.cls.nxv8i16(<vscale x 8 x i16>, <vscale x 8 x i1>, <vscale x 8 x i16>)
980 declare <vscale x 4 x i32> @llvm.aarch64.sve.cls.nxv4i32(<vscale x 4 x i32>, <vscale x 4 x i1>, <vscale x 4 x i32>)
981 declare <vscale x 2 x i64> @llvm.aarch64.sve.cls.nxv2i64(<vscale x 2 x i64>, <vscale x 2 x i1>, <vscale x 2 x i64>)
983 declare <vscale x 8 x half> @llvm.aarch64.sve.fabs.nxv8f16(<vscale x 8 x half>, <vscale x 8 x i1>, <vscale x 8 x half>)
984 declare <vscale x 4 x float> @llvm.aarch64.sve.fabs.nxv4f32(<vscale x 4 x float>, <vscale x 4 x i1>, <vscale x 4 x float>)
985 declare <vscale x 2 x double> @llvm.aarch64.sve.fabs.nxv2f64(<vscale x 2 x double>, <vscale x 2 x i1>, <vscale x 2 x double>)
987 declare <vscale x 8 x half> @llvm.fabs.nxv8f16(<vscale x 8 x half>)
988 declare <vscale x 4 x float> @llvm.fabs.nxv4f32(<vscale x 4 x float>)
989 declare <vscale x 2 x double> @llvm.fabs.nxv2f64(<vscale x 2 x double>)
991 declare <vscale x 8 x i16> @llvm.aarch64.sve.sxtb.nxv8i16(<vscale x 8 x i16>, <vscale x 8 x i1>, <vscale x 8 x i16>)
992 declare <vscale x 4 x i32> @llvm.aarch64.sve.sxtb.nxv4i32(<vscale x 4 x i32>, <vscale x 4 x i1>, <vscale x 4 x i32>)
993 declare <vscale x 2 x i64> @llvm.aarch64.sve.sxtb.nxv2i64(<vscale x 2 x i64>, <vscale x 2 x i1>, <vscale x 2 x i64>)
995 declare <vscale x 4 x i32> @llvm.aarch64.sve.sxth.nxv4i32(<vscale x 4 x i32>, <vscale x 4 x i1>, <vscale x 4 x i32>)
996 declare <vscale x 2 x i64> @llvm.aarch64.sve.sxth.nxv2i64(<vscale x 2 x i64>, <vscale x 2 x i1>, <vscale x 2 x i64>)
998 declare <vscale x 2 x i64> @llvm.aarch64.sve.sxtw.nxv2i64(<vscale x 2 x i64>, <vscale x 2 x i1>, <vscale x 2 x i64>)
1000 attributes #0 = { nounwind "target-features"="+sve" }