1 ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2 ; RUN: llc < %s -mtriple=aarch64 | FileCheck %s
4 define <8 x i16> @abdu_base(<8 x i16> %src1, <8 x i16> %src2) {
5 ; CHECK-LABEL: abdu_base:
7 ; CHECK-NEXT: uabd v0.8h, v0.8h, v1.8h
9 %zextsrc1 = zext <8 x i16> %src1 to <8 x i32>
10 %zextsrc2 = zext <8 x i16> %src2 to <8 x i32>
11 %sub = sub <8 x i32> %zextsrc1, %zextsrc2
12 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
13 %result = trunc <8 x i32> %abs to <8 x i16>
17 define <8 x i16> @abdu_const(<8 x i16> %src1) {
18 ; CHECK-LABEL: abdu_const:
20 ; CHECK-NEXT: movi v1.4s, #1
21 ; CHECK-NEXT: ushll2 v2.4s, v0.8h, #0
22 ; CHECK-NEXT: ushll v0.4s, v0.4h, #0
23 ; CHECK-NEXT: sub v0.4s, v0.4s, v1.4s
24 ; CHECK-NEXT: sub v1.4s, v2.4s, v1.4s
25 ; CHECK-NEXT: abs v1.4s, v1.4s
26 ; CHECK-NEXT: abs v0.4s, v0.4s
27 ; CHECK-NEXT: uzp1 v0.8h, v0.8h, v1.8h
29 %zextsrc1 = zext <8 x i16> %src1 to <8 x i32>
30 %sub = sub <8 x i32> %zextsrc1, <i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1>
31 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
32 %result = trunc <8 x i32> %abs to <8 x i16>
36 define <8 x i16> @abdu_const_lhs(<8 x i16> %src1) {
37 ; CHECK-LABEL: abdu_const_lhs:
39 ; CHECK-NEXT: movi v1.4s, #1
40 ; CHECK-NEXT: usubw v2.4s, v1.4s, v0.4h
41 ; CHECK-NEXT: usubw2 v0.4s, v1.4s, v0.8h
42 ; CHECK-NEXT: abs v0.4s, v0.4s
43 ; CHECK-NEXT: abs v1.4s, v2.4s
44 ; CHECK-NEXT: uzp1 v0.8h, v1.8h, v0.8h
46 %zextsrc1 = zext <8 x i16> %src1 to <8 x i32>
47 %sub = sub <8 x i32> <i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1>, %zextsrc1
48 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
49 %result = trunc <8 x i32> %abs to <8 x i16>
53 define <8 x i16> @abdu_const_zero(<8 x i16> %src1) {
54 ; CHECK-LABEL: abdu_const_zero:
56 ; CHECK-NEXT: movi v1.2d, #0000000000000000
57 ; CHECK-NEXT: ushll v2.4s, v0.4h, #0
58 ; CHECK-NEXT: usubw2 v0.4s, v1.4s, v0.8h
59 ; CHECK-NEXT: neg v1.4s, v2.4s
60 ; CHECK-NEXT: abs v0.4s, v0.4s
61 ; CHECK-NEXT: abs v1.4s, v1.4s
62 ; CHECK-NEXT: uzp1 v0.8h, v1.8h, v0.8h
64 %zextsrc1 = zext <8 x i16> %src1 to <8 x i32>
65 %sub = sub <8 x i32> <i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0>, %zextsrc1
66 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
67 %result = trunc <8 x i32> %abs to <8 x i16>
71 define <8 x i16> @abdu_const_both() {
72 ; CHECK-LABEL: abdu_const_both:
74 ; CHECK-NEXT: movi v0.8h, #2
76 %sub = sub <8 x i32> <i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3>, <i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1>
77 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
78 %result = trunc <8 x i32> %abs to <8 x i16>
82 define <8 x i16> @abdu_const_bothhigh() {
83 ; CHECK-LABEL: abdu_const_bothhigh:
85 ; CHECK-NEXT: movi v0.8h, #1
87 %zextsrc1 = zext <8 x i16> <i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534> to <8 x i32>
88 %zextsrc2 = zext <8 x i16> <i16 65535, i16 65535, i16 65535, i16 65535, i16 65535, i16 65535, i16 65535, i16 65535> to <8 x i32>
89 %sub = sub <8 x i32> %zextsrc1, %zextsrc2
90 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
91 %result = trunc <8 x i32> %abs to <8 x i16>
95 define <8 x i16> @abdu_undef(<8 x i16> %src1) {
96 ; CHECK-LABEL: abdu_undef:
99 %zextsrc1 = zext <8 x i16> %src1 to <8 x i32>
100 %zextsrc2 = zext <8 x i16> undef to <8 x i32>
101 %sub = sub <8 x i32> %zextsrc1, %zextsrc2
102 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
103 %result = trunc <8 x i32> %abs to <8 x i16>
104 ret <8 x i16> %result
107 define <8 x i16> @abdu_ugt(<8 x i16>, <8 x i16>) {
108 ; CHECK-LABEL: abdu_ugt:
110 ; CHECK-NEXT: uabd v0.8h, v0.8h, v1.8h
112 %3 = icmp ugt <8 x i16> %0, %1
113 %4 = sub <8 x i16> %0, %1
114 %5 = sub <8 x i16> %1, %0
115 %6 = select <8 x i1> %3, <8 x i16> %4, <8 x i16> %5
119 define <8 x i16> @abdu_uge(<8 x i16>, <8 x i16>) {
120 ; CHECK-LABEL: abdu_uge:
122 ; CHECK-NEXT: uabd v0.8h, v0.8h, v1.8h
124 %3 = icmp uge <8 x i16> %0, %1
125 %4 = sub <8 x i16> %0, %1
126 %5 = sub <8 x i16> %1, %0
127 %6 = select <8 x i1> %3, <8 x i16> %4, <8 x i16> %5
131 define <8 x i16> @abdu_ult(<8 x i16>, <8 x i16>) {
132 ; CHECK-LABEL: abdu_ult:
134 ; CHECK-NEXT: uabd v0.8h, v0.8h, v1.8h
136 %3 = icmp ult <8 x i16> %0, %1
137 %4 = sub <8 x i16> %0, %1
138 %5 = sub <8 x i16> %1, %0
139 %6 = select <8 x i1> %3, <8 x i16> %5, <8 x i16> %4
143 define <8 x i16> @abdu_ule(<8 x i16>, <8 x i16>) {
144 ; CHECK-LABEL: abdu_ule:
146 ; CHECK-NEXT: uabd v0.8h, v0.8h, v1.8h
148 %3 = icmp ule <8 x i16> %0, %1
149 %4 = sub <8 x i16> %0, %1
150 %5 = sub <8 x i16> %1, %0
151 %6 = select <8 x i1> %3, <8 x i16> %5, <8 x i16> %4
155 define <8 x i16> @abds_sgt(<8 x i16>, <8 x i16>) {
156 ; CHECK-LABEL: abds_sgt:
158 ; CHECK-NEXT: sabd v0.8h, v0.8h, v1.8h
160 %3 = icmp sgt <8 x i16> %0, %1
161 %4 = sub <8 x i16> %0, %1
162 %5 = sub <8 x i16> %1, %0
163 %6 = select <8 x i1> %3, <8 x i16> %4, <8 x i16> %5
167 define <8 x i16> @abds_sge(<8 x i16>, <8 x i16>) {
168 ; CHECK-LABEL: abds_sge:
170 ; CHECK-NEXT: sabd v0.8h, v0.8h, v1.8h
172 %3 = icmp sge <8 x i16> %0, %1
173 %4 = sub <8 x i16> %0, %1
174 %5 = sub <8 x i16> %1, %0
175 %6 = select <8 x i1> %3, <8 x i16> %4, <8 x i16> %5
179 define <8 x i16> @abds_slt(<8 x i16>, <8 x i16>) {
180 ; CHECK-LABEL: abds_slt:
182 ; CHECK-NEXT: sabd v0.8h, v0.8h, v1.8h
184 %3 = icmp slt <8 x i16> %0, %1
185 %4 = sub <8 x i16> %0, %1
186 %5 = sub <8 x i16> %1, %0
187 %6 = select <8 x i1> %3, <8 x i16> %5, <8 x i16> %4
191 define <8 x i16> @abds_sle(<8 x i16>, <8 x i16>) {
192 ; CHECK-LABEL: abds_sle:
194 ; CHECK-NEXT: sabd v0.8h, v0.8h, v1.8h
196 %3 = icmp sle <8 x i16> %0, %1
197 %4 = sub <8 x i16> %0, %1
198 %5 = sub <8 x i16> %1, %0
199 %6 = select <8 x i1> %3, <8 x i16> %5, <8 x i16> %4
204 define <8 x i16> @abdu_i_base(<8 x i16> %src1, <8 x i16> %src2) {
205 ; CHECK-LABEL: abdu_i_base:
207 ; CHECK-NEXT: uabd v0.8h, v0.8h, v1.8h
209 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> %src1, <8 x i16> %src2)
210 ret <8 x i16> %result
213 define <8 x i16> @abdu_i_const(<8 x i16> %src1) {
214 ; CHECK-LABEL: abdu_i_const:
216 ; CHECK-NEXT: movi v1.8h, #1
217 ; CHECK-NEXT: uabd v0.8h, v0.8h, v1.8h
219 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> %src1, <8 x i16> <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>)
220 ret <8 x i16> %result
223 define <8 x i16> @abdu_i_const_lhs(<8 x i16> %src1) {
224 ; CHECK-LABEL: abdu_i_const_lhs:
226 ; CHECK-NEXT: movi v1.8h, #1
227 ; CHECK-NEXT: uabd v0.8h, v0.8h, v1.8h
229 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>, <8 x i16> %src1)
230 ret <8 x i16> %result
233 define <8 x i16> @abdu_i_const_zero(float %t, <8 x i16> %src1) {
234 ; CHECK-LABEL: abdu_i_const_zero:
236 ; CHECK-NEXT: mov v0.16b, v1.16b
238 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, <8 x i16> %src1)
239 ret <8 x i16> %result
242 define <8 x i16> @abdu_i_const_both() {
243 ; CHECK-LABEL: abdu_i_const_both:
245 ; CHECK-NEXT: movi v0.8h, #2
247 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> <i16 3, i16 3, i16 3, i16 3, i16 3, i16 3, i16 3, i16 3>, <8 x i16> <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>)
248 ret <8 x i16> %result
251 define <8 x i16> @abdu_i_const_bothhigh() {
252 ; CHECK-LABEL: abdu_i_const_bothhigh:
254 ; CHECK-NEXT: movi v0.8h, #1
256 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> <i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534>, <8 x i16> <i16 65535, i16 65535, i16 65535, i16 65535, i16 65535, i16 65535, i16 65535, i16 65535>)
257 ret <8 x i16> %result
260 define <8 x i16> @abdu_i_const_onehigh() {
261 ; CHECK-LABEL: abdu_i_const_onehigh:
263 ; CHECK-NEXT: mov w8, #32765 // =0x7ffd
264 ; CHECK-NEXT: dup v0.8h, w8
266 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> <i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766>, <8 x i16> <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>)
267 ret <8 x i16> %result
270 define <8 x i16> @abdu_i_const_oneneg() {
271 ; CHECK-LABEL: abdu_i_const_oneneg:
273 ; CHECK-NEXT: movi v0.8h, #128, lsl #8
275 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> <i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766>, <8 x i16> <i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534>)
276 ret <8 x i16> %result
279 define <8 x i16> @abdu_i_zero(<8 x i16> %t, <8 x i16> %src1) {
280 ; CHECK-LABEL: abdu_i_zero:
282 ; CHECK-NEXT: mov v0.16b, v1.16b
284 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, <8 x i16> %src1)
285 ret <8 x i16> %result
288 define <8 x i16> @abdu_i_undef(<8 x i16> %t, <8 x i16> %src1) {
289 ; CHECK-LABEL: abdu_i_undef:
291 ; CHECK-NEXT: movi v0.2d, #0000000000000000
293 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> undef, <8 x i16> %src1)
294 ret <8 x i16> %result
297 define <8 x i16> @abdu_i_reassoc(<8 x i16> %src1) {
298 ; CHECK-LABEL: abdu_i_reassoc:
300 ; CHECK-NEXT: movi v1.8h, #3
301 ; CHECK-NEXT: movi v2.8h, #1
302 ; CHECK-NEXT: uabd v0.8h, v0.8h, v1.8h
303 ; CHECK-NEXT: uabd v0.8h, v0.8h, v2.8h
305 %r1 = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> %src1, <8 x i16> <i16 3, i16 3, i16 3, i16 3, i16 3, i16 3, i16 3, i16 3>)
306 %result = call <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16> %r1, <8 x i16> <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>)
307 ret <8 x i16> %result
314 define <8 x i16> @abds_base(<8 x i16> %src1, <8 x i16> %src2) {
315 ; CHECK-LABEL: abds_base:
317 ; CHECK-NEXT: sabd v0.8h, v0.8h, v1.8h
319 %zextsrc1 = sext <8 x i16> %src1 to <8 x i32>
320 %zextsrc2 = sext <8 x i16> %src2 to <8 x i32>
321 %sub = sub <8 x i32> %zextsrc1, %zextsrc2
322 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
323 %result = trunc <8 x i32> %abs to <8 x i16>
324 ret <8 x i16> %result
327 define <8 x i16> @abds_const(<8 x i16> %src1) {
328 ; CHECK-LABEL: abds_const:
330 ; CHECK-NEXT: movi v1.4s, #1
331 ; CHECK-NEXT: sshll2 v2.4s, v0.8h, #0
332 ; CHECK-NEXT: sshll v0.4s, v0.4h, #0
333 ; CHECK-NEXT: sub v0.4s, v0.4s, v1.4s
334 ; CHECK-NEXT: sub v1.4s, v2.4s, v1.4s
335 ; CHECK-NEXT: abs v1.4s, v1.4s
336 ; CHECK-NEXT: abs v0.4s, v0.4s
337 ; CHECK-NEXT: uzp1 v0.8h, v0.8h, v1.8h
339 %zextsrc1 = sext <8 x i16> %src1 to <8 x i32>
340 %sub = sub <8 x i32> %zextsrc1, <i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1>
341 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
342 %result = trunc <8 x i32> %abs to <8 x i16>
343 ret <8 x i16> %result
346 define <8 x i16> @abds_const_lhs(<8 x i16> %src1) {
347 ; CHECK-LABEL: abds_const_lhs:
349 ; CHECK-NEXT: movi v1.4s, #1
350 ; CHECK-NEXT: ssubw v2.4s, v1.4s, v0.4h
351 ; CHECK-NEXT: ssubw2 v0.4s, v1.4s, v0.8h
352 ; CHECK-NEXT: abs v0.4s, v0.4s
353 ; CHECK-NEXT: abs v1.4s, v2.4s
354 ; CHECK-NEXT: uzp1 v0.8h, v1.8h, v0.8h
356 %zextsrc1 = sext <8 x i16> %src1 to <8 x i32>
357 %sub = sub <8 x i32> <i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1>, %zextsrc1
358 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
359 %result = trunc <8 x i32> %abs to <8 x i16>
360 ret <8 x i16> %result
363 define <8 x i16> @abds_const_zero(<8 x i16> %src1) {
364 ; CHECK-LABEL: abds_const_zero:
366 ; CHECK-NEXT: movi v1.2d, #0000000000000000
367 ; CHECK-NEXT: sshll v2.4s, v0.4h, #0
368 ; CHECK-NEXT: ssubw2 v0.4s, v1.4s, v0.8h
369 ; CHECK-NEXT: neg v1.4s, v2.4s
370 ; CHECK-NEXT: abs v0.4s, v0.4s
371 ; CHECK-NEXT: abs v1.4s, v1.4s
372 ; CHECK-NEXT: uzp1 v0.8h, v1.8h, v0.8h
374 %zextsrc1 = sext <8 x i16> %src1 to <8 x i32>
375 %sub = sub <8 x i32> <i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0>, %zextsrc1
376 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
377 %result = trunc <8 x i32> %abs to <8 x i16>
378 ret <8 x i16> %result
381 define <8 x i16> @abds_const_both() {
382 ; CHECK-LABEL: abds_const_both:
384 ; CHECK-NEXT: movi v0.8h, #2
386 %sub = sub <8 x i32> <i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3, i32 3>, <i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1, i32 1>
387 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
388 %result = trunc <8 x i32> %abs to <8 x i16>
389 ret <8 x i16> %result
392 define <8 x i16> @abds_const_bothhigh() {
393 ; CHECK-LABEL: abds_const_bothhigh:
395 ; CHECK-NEXT: movi v0.8h, #1
397 %zextsrc1 = sext <8 x i16> <i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534> to <8 x i32>
398 %zextsrc2 = sext <8 x i16> <i16 65535, i16 65535, i16 65535, i16 65535, i16 65535, i16 65535, i16 65535, i16 65535> to <8 x i32>
399 %sub = sub <8 x i32> %zextsrc1, %zextsrc2
400 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
401 %result = trunc <8 x i32> %abs to <8 x i16>
402 ret <8 x i16> %result
405 define <8 x i16> @abds_undef(<8 x i16> %src1) {
406 ; CHECK-LABEL: abds_undef:
408 ; CHECK-NEXT: sshll v1.4s, v0.4h, #0
409 ; CHECK-NEXT: sshll2 v0.4s, v0.8h, #0
410 ; CHECK-NEXT: abs v0.4s, v0.4s
411 ; CHECK-NEXT: abs v1.4s, v1.4s
412 ; CHECK-NEXT: uzp1 v0.8h, v1.8h, v0.8h
414 %zextsrc1 = sext <8 x i16> %src1 to <8 x i32>
415 %zextsrc2 = sext <8 x i16> undef to <8 x i32>
416 %sub = sub <8 x i32> %zextsrc1, %zextsrc2
417 %abs = call <8 x i32> @llvm.abs.v8i32(<8 x i32> %sub, i1 0)
418 %result = trunc <8 x i32> %abs to <8 x i16>
419 ret <8 x i16> %result
424 define <8 x i16> @abds_i_base(<8 x i16> %src1, <8 x i16> %src2) {
425 ; CHECK-LABEL: abds_i_base:
427 ; CHECK-NEXT: sabd v0.8h, v0.8h, v1.8h
429 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> %src1, <8 x i16> %src2)
430 ret <8 x i16> %result
433 define <8 x i16> @abds_i_const(<8 x i16> %src1) {
434 ; CHECK-LABEL: abds_i_const:
436 ; CHECK-NEXT: movi v1.8h, #1
437 ; CHECK-NEXT: sabd v0.8h, v0.8h, v1.8h
439 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> %src1, <8 x i16> <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>)
440 ret <8 x i16> %result
443 define <8 x i16> @abds_i_const_lhs(<8 x i16> %src1) {
444 ; CHECK-LABEL: abds_i_const_lhs:
446 ; CHECK-NEXT: movi v1.8h, #1
447 ; CHECK-NEXT: sabd v0.8h, v0.8h, v1.8h
449 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>, <8 x i16> %src1)
450 ret <8 x i16> %result
453 define <8 x i16> @abds_i_const_zero(<8 x i16> %src1) {
454 ; CHECK-LABEL: abds_i_const_zero:
456 ; CHECK-NEXT: abs v0.8h, v0.8h
458 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, <8 x i16> %src1)
459 ret <8 x i16> %result
462 define <8 x i16> @abds_i_const_both() {
463 ; CHECK-LABEL: abds_i_const_both:
465 ; CHECK-NEXT: movi v0.8h, #2
467 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> <i16 3, i16 3, i16 3, i16 3, i16 3, i16 3, i16 3, i16 3>, <8 x i16> <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>)
468 ret <8 x i16> %result
471 define <8 x i16> @abds_i_const_bothhigh() {
472 ; CHECK-LABEL: abds_i_const_bothhigh:
474 ; CHECK-NEXT: movi v0.8h, #1
476 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> <i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766>, <8 x i16> <i16 32767, i16 32767, i16 32767, i16 32767, i16 32767, i16 32767, i16 32767, i16 32767>)
477 ret <8 x i16> %result
480 define <8 x i16> @abds_i_const_onehigh() {
481 ; CHECK-LABEL: abds_i_const_onehigh:
483 ; CHECK-NEXT: mov w8, #32765 // =0x7ffd
484 ; CHECK-NEXT: dup v0.8h, w8
486 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> <i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766>, <8 x i16> <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>)
487 ret <8 x i16> %result
490 define <8 x i16> @abds_i_const_oneneg() {
491 ; CHECK-LABEL: abds_i_const_oneneg:
493 ; CHECK-NEXT: movi v0.8h, #128, lsl #8
495 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> <i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766, i16 32766>, <8 x i16> <i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534, i16 65534>)
496 ret <8 x i16> %result
499 define <8 x i16> @abds_i_zero(<8 x i16> %t, <8 x i16> %src1) {
500 ; CHECK-LABEL: abds_i_zero:
502 ; CHECK-NEXT: abs v0.8h, v1.8h
504 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> <i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0, i16 0>, <8 x i16> %src1)
505 ret <8 x i16> %result
508 define <8 x i16> @abds_i_undef(<8 x i16> %t, <8 x i16> %src1) {
509 ; CHECK-LABEL: abds_i_undef:
511 ; CHECK-NEXT: movi v0.2d, #0000000000000000
513 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> undef, <8 x i16> %src1)
514 ret <8 x i16> %result
517 define <8 x i16> @abds_i_reassoc(<8 x i16> %src1) {
518 ; CHECK-LABEL: abds_i_reassoc:
520 ; CHECK-NEXT: movi v1.8h, #3
521 ; CHECK-NEXT: movi v2.8h, #1
522 ; CHECK-NEXT: sabd v0.8h, v0.8h, v1.8h
523 ; CHECK-NEXT: sabd v0.8h, v0.8h, v2.8h
525 %r1 = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> %src1, <8 x i16> <i16 3, i16 3, i16 3, i16 3, i16 3, i16 3, i16 3, i16 3>)
526 %result = call <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16> %r1, <8 x i16> <i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1, i16 1>)
527 ret <8 x i16> %result
530 define <1 x i64> @recursive() {
531 ; CHECK-LABEL: recursive:
533 ; CHECK-NEXT: movi v0.2d, #0xffffffffffffffff
534 ; CHECK-NEXT: movi v1.8b, #1
535 ; CHECK-NEXT: uabd v2.8b, v1.8b, v0.8b
536 ; CHECK-NEXT: uabdl v0.8h, v1.8b, v0.8b
537 ; CHECK-NEXT: dup v1.8b, v2.b[0]
538 ; CHECK-NEXT: saddlp v0.1d, v0.2s
539 ; CHECK-NEXT: orr v0.8b, v1.8b, v0.8b
541 %1 = tail call <8 x i8> @llvm.aarch64.neon.umax.v8i8(<8 x i8> zeroinitializer, <8 x i8> <i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1, i8 -1>)
542 %2 = tail call <8 x i8> @llvm.aarch64.neon.uabd.v8i8(<8 x i8> %1, <8 x i8> <i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1, i8 1>)
543 %3 = zext <8 x i8> %2 to <8 x i16>
544 %4 = bitcast <8 x i16> %3 to <4 x i32>
545 %5 = shufflevector <4 x i32> %4, <4 x i32> zeroinitializer, <2 x i32> <i32 0, i32 1>
546 %6 = shufflevector <8 x i8> %2, <8 x i8> zeroinitializer, <16 x i32> <i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 0, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison, i32 poison>
547 %7 = bitcast <16 x i8> %6 to <2 x i64>
548 %8 = shufflevector <2 x i64> %7, <2 x i64> zeroinitializer, <1 x i32> zeroinitializer
549 %9 = tail call <1 x i64> @llvm.aarch64.neon.saddlp.v1i64.v2i32(<2 x i32> %5)
550 %10 = or <1 x i64> %8, %9
554 declare <8 x i8> @llvm.aarch64.neon.umax.v8i8(<8 x i8>, <8 x i8>)
555 declare <1 x i64> @llvm.aarch64.neon.saddlp.v1i64.v2i32(<2 x i32>)
556 declare <8 x i8> @llvm.aarch64.neon.uabd.v8i8(<8 x i8>, <8 x i8>)
557 declare <8 x i16> @llvm.aarch64.neon.uabd.v8i16(<8 x i16>, <8 x i16>)
558 declare <8 x i16> @llvm.aarch64.neon.sabd.v8i16(<8 x i16>, <8 x i16>)
559 declare <8 x i32> @llvm.abs.v8i32(<8 x i32>, i1)