1 ; RUN: llc < %s -mtriple=arm64-eabi -aarch64-neon-syntax=apple -asm-verbose=false | FileCheck %s
3 define <8 x i8> @addhn8b(ptr %A, ptr %B) nounwind {
6 %tmp1 = load <8 x i16>, ptr %A
7 %tmp2 = load <8 x i16>, ptr %B
8 %tmp3 = call <8 x i8> @llvm.aarch64.neon.addhn.v8i8(<8 x i16> %tmp1, <8 x i16> %tmp2)
12 define <4 x i16> @addhn4h(ptr %A, ptr %B) nounwind {
13 ;CHECK-LABEL: addhn4h:
15 %tmp1 = load <4 x i32>, ptr %A
16 %tmp2 = load <4 x i32>, ptr %B
17 %tmp3 = call <4 x i16> @llvm.aarch64.neon.addhn.v4i16(<4 x i32> %tmp1, <4 x i32> %tmp2)
21 define <2 x i32> @addhn2s(ptr %A, ptr %B) nounwind {
22 ;CHECK-LABEL: addhn2s:
24 %tmp1 = load <2 x i64>, ptr %A
25 %tmp2 = load <2 x i64>, ptr %B
26 %tmp3 = call <2 x i32> @llvm.aarch64.neon.addhn.v2i32(<2 x i64> %tmp1, <2 x i64> %tmp2)
30 define <16 x i8> @addhn2_16b(<8 x i16> %a, <8 x i16> %b) nounwind {
31 ;CHECK-LABEL: addhn2_16b:
33 ;CHECK-NEXT: addhn2.16b
34 %vaddhn2.i = tail call <8 x i8> @llvm.aarch64.neon.addhn.v8i8(<8 x i16> %a, <8 x i16> %b) nounwind
35 %vaddhn_high2.i = tail call <8 x i8> @llvm.aarch64.neon.addhn.v8i8(<8 x i16> %a, <8 x i16> %b) nounwind
36 %res = shufflevector <8 x i8> %vaddhn2.i, <8 x i8> %vaddhn_high2.i, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15>
40 define <8 x i16> @addhn2_8h(<4 x i32> %a, <4 x i32> %b) nounwind {
41 ;CHECK-LABEL: addhn2_8h:
43 ;CHECK-NEXT: addhn2.8h
44 %vaddhn2.i = tail call <4 x i16> @llvm.aarch64.neon.addhn.v4i16(<4 x i32> %a, <4 x i32> %b) nounwind
45 %vaddhn_high3.i = tail call <4 x i16> @llvm.aarch64.neon.addhn.v4i16(<4 x i32> %a, <4 x i32> %b) nounwind
46 %res = shufflevector <4 x i16> %vaddhn2.i, <4 x i16> %vaddhn_high3.i, <8 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7>
50 define <4 x i32> @addhn2_4s(<2 x i64> %a, <2 x i64> %b) nounwind {
51 ;CHECK-LABEL: addhn2_4s:
53 ;CHECK-NEXT: addhn2.4s
54 %vaddhn2.i = tail call <2 x i32> @llvm.aarch64.neon.addhn.v2i32(<2 x i64> %a, <2 x i64> %b) nounwind
55 %vaddhn_high3.i = tail call <2 x i32> @llvm.aarch64.neon.addhn.v2i32(<2 x i64> %a, <2 x i64> %b) nounwind
56 %res = shufflevector <2 x i32> %vaddhn2.i, <2 x i32> %vaddhn_high3.i, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
60 declare <2 x i32> @llvm.aarch64.neon.addhn.v2i32(<2 x i64>, <2 x i64>) nounwind readnone
61 declare <4 x i16> @llvm.aarch64.neon.addhn.v4i16(<4 x i32>, <4 x i32>) nounwind readnone
62 declare <8 x i8> @llvm.aarch64.neon.addhn.v8i8(<8 x i16>, <8 x i16>) nounwind readnone
65 define <8 x i8> @raddhn8b(ptr %A, ptr %B) nounwind {
66 ;CHECK-LABEL: raddhn8b:
68 %tmp1 = load <8 x i16>, ptr %A
69 %tmp2 = load <8 x i16>, ptr %B
70 %tmp3 = call <8 x i8> @llvm.aarch64.neon.raddhn.v8i8(<8 x i16> %tmp1, <8 x i16> %tmp2)
74 define <4 x i16> @raddhn4h(ptr %A, ptr %B) nounwind {
75 ;CHECK-LABEL: raddhn4h:
77 %tmp1 = load <4 x i32>, ptr %A
78 %tmp2 = load <4 x i32>, ptr %B
79 %tmp3 = call <4 x i16> @llvm.aarch64.neon.raddhn.v4i16(<4 x i32> %tmp1, <4 x i32> %tmp2)
83 define <2 x i32> @raddhn2s(ptr %A, ptr %B) nounwind {
84 ;CHECK-LABEL: raddhn2s:
86 %tmp1 = load <2 x i64>, ptr %A
87 %tmp2 = load <2 x i64>, ptr %B
88 %tmp3 = call <2 x i32> @llvm.aarch64.neon.raddhn.v2i32(<2 x i64> %tmp1, <2 x i64> %tmp2)
92 define <16 x i8> @raddhn2_16b(<8 x i16> %a, <8 x i16> %b) nounwind {
93 ;CHECK-LABEL: raddhn2_16b:
95 ;CHECK-NEXT: raddhn2.16b
96 %vraddhn2.i = tail call <8 x i8> @llvm.aarch64.neon.raddhn.v8i8(<8 x i16> %a, <8 x i16> %b) nounwind
97 %vraddhn_high2.i = tail call <8 x i8> @llvm.aarch64.neon.raddhn.v8i8(<8 x i16> %a, <8 x i16> %b) nounwind
98 %res = shufflevector <8 x i8> %vraddhn2.i, <8 x i8> %vraddhn_high2.i, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15>
102 define <8 x i16> @raddhn2_8h(<4 x i32> %a, <4 x i32> %b) nounwind {
103 ;CHECK-LABEL: raddhn2_8h:
105 ;CHECK-NEXT: raddhn2.8h
106 %vraddhn2.i = tail call <4 x i16> @llvm.aarch64.neon.raddhn.v4i16(<4 x i32> %a, <4 x i32> %b) nounwind
107 %vraddhn_high3.i = tail call <4 x i16> @llvm.aarch64.neon.raddhn.v4i16(<4 x i32> %a, <4 x i32> %b) nounwind
108 %res = shufflevector <4 x i16> %vraddhn2.i, <4 x i16> %vraddhn_high3.i, <8 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7>
112 define <4 x i32> @raddhn2_4s(<2 x i64> %a, <2 x i64> %b) nounwind {
113 ;CHECK-LABEL: raddhn2_4s:
115 ;CHECK-NEXT: raddhn2.4s
116 %vraddhn2.i = tail call <2 x i32> @llvm.aarch64.neon.raddhn.v2i32(<2 x i64> %a, <2 x i64> %b) nounwind
117 %vraddhn_high3.i = tail call <2 x i32> @llvm.aarch64.neon.raddhn.v2i32(<2 x i64> %a, <2 x i64> %b) nounwind
118 %res = shufflevector <2 x i32> %vraddhn2.i, <2 x i32> %vraddhn_high3.i, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
122 declare <2 x i32> @llvm.aarch64.neon.raddhn.v2i32(<2 x i64>, <2 x i64>) nounwind readnone
123 declare <4 x i16> @llvm.aarch64.neon.raddhn.v4i16(<4 x i32>, <4 x i32>) nounwind readnone
124 declare <8 x i8> @llvm.aarch64.neon.raddhn.v8i8(<8 x i16>, <8 x i16>) nounwind readnone
126 define <8 x i16> @saddl8h(ptr %A, ptr %B) nounwind {
127 ;CHECK-LABEL: saddl8h:
129 %tmp1 = load <8 x i8>, ptr %A
130 %tmp2 = load <8 x i8>, ptr %B
131 %tmp3 = sext <8 x i8> %tmp1 to <8 x i16>
132 %tmp4 = sext <8 x i8> %tmp2 to <8 x i16>
133 %tmp5 = add <8 x i16> %tmp3, %tmp4
137 define <4 x i32> @saddl4s(ptr %A, ptr %B) nounwind {
138 ;CHECK-LABEL: saddl4s:
140 %tmp1 = load <4 x i16>, ptr %A
141 %tmp2 = load <4 x i16>, ptr %B
142 %tmp3 = sext <4 x i16> %tmp1 to <4 x i32>
143 %tmp4 = sext <4 x i16> %tmp2 to <4 x i32>
144 %tmp5 = add <4 x i32> %tmp3, %tmp4
148 define <2 x i64> @saddl2d(ptr %A, ptr %B) nounwind {
149 ;CHECK-LABEL: saddl2d:
151 %tmp1 = load <2 x i32>, ptr %A
152 %tmp2 = load <2 x i32>, ptr %B
153 %tmp3 = sext <2 x i32> %tmp1 to <2 x i64>
154 %tmp4 = sext <2 x i32> %tmp2 to <2 x i64>
155 %tmp5 = add <2 x i64> %tmp3, %tmp4
159 define <8 x i16> @saddl2_8h(<16 x i8> %a, <16 x i8> %b) nounwind {
160 ; CHECK-LABEL: saddl2_8h:
161 ; CHECK-NEXT: saddl2.8h v0, v0, v1
163 %tmp = bitcast <16 x i8> %a to <2 x i64>
164 %shuffle.i.i.i = shufflevector <2 x i64> %tmp, <2 x i64> undef, <1 x i32> <i32 1>
165 %tmp1 = bitcast <1 x i64> %shuffle.i.i.i to <8 x i8>
166 %vmovl.i.i.i = sext <8 x i8> %tmp1 to <8 x i16>
167 %tmp2 = bitcast <16 x i8> %b to <2 x i64>
168 %shuffle.i.i4.i = shufflevector <2 x i64> %tmp2, <2 x i64> undef, <1 x i32> <i32 1>
169 %tmp3 = bitcast <1 x i64> %shuffle.i.i4.i to <8 x i8>
170 %vmovl.i.i5.i = sext <8 x i8> %tmp3 to <8 x i16>
171 %add.i = add <8 x i16> %vmovl.i.i.i, %vmovl.i.i5.i
175 define <4 x i32> @saddl2_4s(<8 x i16> %a, <8 x i16> %b) nounwind {
176 ; CHECK-LABEL: saddl2_4s:
177 ; CHECK-NEXT: saddl2.4s v0, v0, v1
179 %tmp = bitcast <8 x i16> %a to <2 x i64>
180 %shuffle.i.i.i = shufflevector <2 x i64> %tmp, <2 x i64> undef, <1 x i32> <i32 1>
181 %tmp1 = bitcast <1 x i64> %shuffle.i.i.i to <4 x i16>
182 %vmovl.i.i.i = sext <4 x i16> %tmp1 to <4 x i32>
183 %tmp2 = bitcast <8 x i16> %b to <2 x i64>
184 %shuffle.i.i4.i = shufflevector <2 x i64> %tmp2, <2 x i64> undef, <1 x i32> <i32 1>
185 %tmp3 = bitcast <1 x i64> %shuffle.i.i4.i to <4 x i16>
186 %vmovl.i.i5.i = sext <4 x i16> %tmp3 to <4 x i32>
187 %add.i = add <4 x i32> %vmovl.i.i.i, %vmovl.i.i5.i
191 define <2 x i64> @saddl2_2d(<4 x i32> %a, <4 x i32> %b) nounwind {
192 ; CHECK-LABEL: saddl2_2d:
193 ; CHECK-NEXT: saddl2.2d v0, v0, v1
195 %tmp = bitcast <4 x i32> %a to <2 x i64>
196 %shuffle.i.i.i = shufflevector <2 x i64> %tmp, <2 x i64> undef, <1 x i32> <i32 1>
197 %tmp1 = bitcast <1 x i64> %shuffle.i.i.i to <2 x i32>
198 %vmovl.i.i.i = sext <2 x i32> %tmp1 to <2 x i64>
199 %tmp2 = bitcast <4 x i32> %b to <2 x i64>
200 %shuffle.i.i4.i = shufflevector <2 x i64> %tmp2, <2 x i64> undef, <1 x i32> <i32 1>
201 %tmp3 = bitcast <1 x i64> %shuffle.i.i4.i to <2 x i32>
202 %vmovl.i.i5.i = sext <2 x i32> %tmp3 to <2 x i64>
203 %add.i = add <2 x i64> %vmovl.i.i.i, %vmovl.i.i5.i
207 define <8 x i16> @uaddl8h(ptr %A, ptr %B) nounwind {
208 ;CHECK-LABEL: uaddl8h:
210 %tmp1 = load <8 x i8>, ptr %A
211 %tmp2 = load <8 x i8>, ptr %B
212 %tmp3 = zext <8 x i8> %tmp1 to <8 x i16>
213 %tmp4 = zext <8 x i8> %tmp2 to <8 x i16>
214 %tmp5 = add <8 x i16> %tmp3, %tmp4
218 define <4 x i32> @uaddl4s(ptr %A, ptr %B) nounwind {
219 ;CHECK-LABEL: uaddl4s:
221 %tmp1 = load <4 x i16>, ptr %A
222 %tmp2 = load <4 x i16>, ptr %B
223 %tmp3 = zext <4 x i16> %tmp1 to <4 x i32>
224 %tmp4 = zext <4 x i16> %tmp2 to <4 x i32>
225 %tmp5 = add <4 x i32> %tmp3, %tmp4
229 define <2 x i64> @uaddl2d(ptr %A, ptr %B) nounwind {
230 ;CHECK-LABEL: uaddl2d:
232 %tmp1 = load <2 x i32>, ptr %A
233 %tmp2 = load <2 x i32>, ptr %B
234 %tmp3 = zext <2 x i32> %tmp1 to <2 x i64>
235 %tmp4 = zext <2 x i32> %tmp2 to <2 x i64>
236 %tmp5 = add <2 x i64> %tmp3, %tmp4
241 define <8 x i16> @uaddl2_8h(<16 x i8> %a, <16 x i8> %b) nounwind {
242 ; CHECK-LABEL: uaddl2_8h:
243 ; CHECK-NEXT: uaddl2.8h v0, v0, v1
245 %tmp = bitcast <16 x i8> %a to <2 x i64>
246 %shuffle.i.i.i = shufflevector <2 x i64> %tmp, <2 x i64> undef, <1 x i32> <i32 1>
247 %tmp1 = bitcast <1 x i64> %shuffle.i.i.i to <8 x i8>
248 %vmovl.i.i.i = zext <8 x i8> %tmp1 to <8 x i16>
249 %tmp2 = bitcast <16 x i8> %b to <2 x i64>
250 %shuffle.i.i4.i = shufflevector <2 x i64> %tmp2, <2 x i64> undef, <1 x i32> <i32 1>
251 %tmp3 = bitcast <1 x i64> %shuffle.i.i4.i to <8 x i8>
252 %vmovl.i.i5.i = zext <8 x i8> %tmp3 to <8 x i16>
253 %add.i = add <8 x i16> %vmovl.i.i.i, %vmovl.i.i5.i
257 define <4 x i32> @uaddl2_4s(<8 x i16> %a, <8 x i16> %b) nounwind {
258 ; CHECK-LABEL: uaddl2_4s:
259 ; CHECK-NEXT: uaddl2.4s v0, v0, v1
261 %tmp = bitcast <8 x i16> %a to <2 x i64>
262 %shuffle.i.i.i = shufflevector <2 x i64> %tmp, <2 x i64> undef, <1 x i32> <i32 1>
263 %tmp1 = bitcast <1 x i64> %shuffle.i.i.i to <4 x i16>
264 %vmovl.i.i.i = zext <4 x i16> %tmp1 to <4 x i32>
265 %tmp2 = bitcast <8 x i16> %b to <2 x i64>
266 %shuffle.i.i4.i = shufflevector <2 x i64> %tmp2, <2 x i64> undef, <1 x i32> <i32 1>
267 %tmp3 = bitcast <1 x i64> %shuffle.i.i4.i to <4 x i16>
268 %vmovl.i.i5.i = zext <4 x i16> %tmp3 to <4 x i32>
269 %add.i = add <4 x i32> %vmovl.i.i.i, %vmovl.i.i5.i
273 define <2 x i64> @uaddl2_2d(<4 x i32> %a, <4 x i32> %b) nounwind {
274 ; CHECK-LABEL: uaddl2_2d:
275 ; CHECK-NEXT: uaddl2.2d v0, v0, v1
277 %tmp = bitcast <4 x i32> %a to <2 x i64>
278 %shuffle.i.i.i = shufflevector <2 x i64> %tmp, <2 x i64> undef, <1 x i32> <i32 1>
279 %tmp1 = bitcast <1 x i64> %shuffle.i.i.i to <2 x i32>
280 %vmovl.i.i.i = zext <2 x i32> %tmp1 to <2 x i64>
281 %tmp2 = bitcast <4 x i32> %b to <2 x i64>
282 %shuffle.i.i4.i = shufflevector <2 x i64> %tmp2, <2 x i64> undef, <1 x i32> <i32 1>
283 %tmp3 = bitcast <1 x i64> %shuffle.i.i4.i to <2 x i32>
284 %vmovl.i.i5.i = zext <2 x i32> %tmp3 to <2 x i64>
285 %add.i = add <2 x i64> %vmovl.i.i.i, %vmovl.i.i5.i
289 define <8 x i16> @uaddw8h(ptr %A, ptr %B) nounwind {
290 ;CHECK-LABEL: uaddw8h:
292 %tmp1 = load <8 x i16>, ptr %A
293 %tmp2 = load <8 x i8>, ptr %B
294 %tmp3 = zext <8 x i8> %tmp2 to <8 x i16>
295 %tmp4 = add <8 x i16> %tmp1, %tmp3
299 define <4 x i32> @uaddw4s(ptr %A, ptr %B) nounwind {
300 ;CHECK-LABEL: uaddw4s:
302 %tmp1 = load <4 x i32>, ptr %A
303 %tmp2 = load <4 x i16>, ptr %B
304 %tmp3 = zext <4 x i16> %tmp2 to <4 x i32>
305 %tmp4 = add <4 x i32> %tmp1, %tmp3
309 define <2 x i64> @uaddw2d(ptr %A, ptr %B) nounwind {
310 ;CHECK-LABEL: uaddw2d:
312 %tmp1 = load <2 x i64>, ptr %A
313 %tmp2 = load <2 x i32>, ptr %B
314 %tmp3 = zext <2 x i32> %tmp2 to <2 x i64>
315 %tmp4 = add <2 x i64> %tmp1, %tmp3
319 define <8 x i16> @uaddw2_8h(ptr %A, ptr %B) nounwind {
320 ;CHECK-LABEL: uaddw2_8h:
322 %tmp1 = load <8 x i16>, ptr %A
324 %tmp2 = load <16 x i8>, ptr %B
325 %high2 = shufflevector <16 x i8> %tmp2, <16 x i8> undef, <8 x i32> <i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15>
326 %ext2 = zext <8 x i8> %high2 to <8 x i16>
328 %res = add <8 x i16> %tmp1, %ext2
332 define <4 x i32> @uaddw2_4s(ptr %A, ptr %B) nounwind {
333 ;CHECK-LABEL: uaddw2_4s:
335 %tmp1 = load <4 x i32>, ptr %A
337 %tmp2 = load <8 x i16>, ptr %B
338 %high2 = shufflevector <8 x i16> %tmp2, <8 x i16> undef, <4 x i32> <i32 4, i32 5, i32 6, i32 7>
339 %ext2 = zext <4 x i16> %high2 to <4 x i32>
341 %res = add <4 x i32> %tmp1, %ext2
345 define <2 x i64> @uaddw2_2d(ptr %A, ptr %B) nounwind {
346 ;CHECK-LABEL: uaddw2_2d:
348 %tmp1 = load <2 x i64>, ptr %A
350 %tmp2 = load <4 x i32>, ptr %B
351 %high2 = shufflevector <4 x i32> %tmp2, <4 x i32> undef, <2 x i32> <i32 2, i32 3>
352 %ext2 = zext <2 x i32> %high2 to <2 x i64>
354 %res = add <2 x i64> %tmp1, %ext2
358 define <8 x i16> @saddw8h(ptr %A, ptr %B) nounwind {
359 ;CHECK-LABEL: saddw8h:
361 %tmp1 = load <8 x i16>, ptr %A
362 %tmp2 = load <8 x i8>, ptr %B
363 %tmp3 = sext <8 x i8> %tmp2 to <8 x i16>
364 %tmp4 = add <8 x i16> %tmp1, %tmp3
368 define <4 x i32> @saddw4s(ptr %A, ptr %B) nounwind {
369 ;CHECK-LABEL: saddw4s:
371 %tmp1 = load <4 x i32>, ptr %A
372 %tmp2 = load <4 x i16>, ptr %B
373 %tmp3 = sext <4 x i16> %tmp2 to <4 x i32>
374 %tmp4 = add <4 x i32> %tmp1, %tmp3
378 define <2 x i64> @saddw2d(ptr %A, ptr %B) nounwind {
379 ;CHECK-LABEL: saddw2d:
381 %tmp1 = load <2 x i64>, ptr %A
382 %tmp2 = load <2 x i32>, ptr %B
383 %tmp3 = sext <2 x i32> %tmp2 to <2 x i64>
384 %tmp4 = add <2 x i64> %tmp1, %tmp3
388 define <8 x i16> @saddw2_8h(ptr %A, ptr %B) nounwind {
389 ;CHECK-LABEL: saddw2_8h:
391 %tmp1 = load <8 x i16>, ptr %A
393 %tmp2 = load <16 x i8>, ptr %B
394 %high2 = shufflevector <16 x i8> %tmp2, <16 x i8> undef, <8 x i32> <i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15>
395 %ext2 = sext <8 x i8> %high2 to <8 x i16>
397 %res = add <8 x i16> %tmp1, %ext2
401 define <4 x i32> @saddw2_4s(ptr %A, ptr %B) nounwind {
402 ;CHECK-LABEL: saddw2_4s:
404 %tmp1 = load <4 x i32>, ptr %A
406 %tmp2 = load <8 x i16>, ptr %B
407 %high2 = shufflevector <8 x i16> %tmp2, <8 x i16> undef, <4 x i32> <i32 4, i32 5, i32 6, i32 7>
408 %ext2 = sext <4 x i16> %high2 to <4 x i32>
410 %res = add <4 x i32> %tmp1, %ext2
414 define <2 x i64> @saddw2_2d(ptr %A, ptr %B) nounwind {
415 ;CHECK-LABEL: saddw2_2d:
417 %tmp1 = load <2 x i64>, ptr %A
419 %tmp2 = load <4 x i32>, ptr %B
420 %high2 = shufflevector <4 x i32> %tmp2, <4 x i32> undef, <2 x i32> <i32 2, i32 3>
421 %ext2 = sext <2 x i32> %high2 to <2 x i64>
423 %res = add <2 x i64> %tmp1, %ext2
427 define <4 x i16> @saddlp4h(ptr %A) nounwind {
428 ;CHECK-LABEL: saddlp4h:
430 %tmp1 = load <8 x i8>, ptr %A
431 %tmp3 = call <4 x i16> @llvm.aarch64.neon.saddlp.v4i16.v8i8(<8 x i8> %tmp1)
435 define <2 x i32> @saddlp2s(ptr %A) nounwind {
436 ;CHECK-LABEL: saddlp2s:
438 %tmp1 = load <4 x i16>, ptr %A
439 %tmp3 = call <2 x i32> @llvm.aarch64.neon.saddlp.v2i32.v4i16(<4 x i16> %tmp1)
443 define <1 x i64> @saddlp1d(ptr %A) nounwind {
444 ;CHECK-LABEL: saddlp1d:
446 %tmp1 = load <2 x i32>, ptr %A
447 %tmp3 = call <1 x i64> @llvm.aarch64.neon.saddlp.v1i64.v2i32(<2 x i32> %tmp1)
451 define <8 x i16> @saddlp8h(ptr %A) nounwind {
452 ;CHECK-LABEL: saddlp8h:
454 %tmp1 = load <16 x i8>, ptr %A
455 %tmp3 = call <8 x i16> @llvm.aarch64.neon.saddlp.v8i16.v16i8(<16 x i8> %tmp1)
459 define <4 x i32> @saddlp4s(ptr %A) nounwind {
460 ;CHECK-LABEL: saddlp4s:
462 %tmp1 = load <8 x i16>, ptr %A
463 %tmp3 = call <4 x i32> @llvm.aarch64.neon.saddlp.v4i32.v8i16(<8 x i16> %tmp1)
467 define <2 x i64> @saddlp2d(ptr %A) nounwind {
468 ;CHECK-LABEL: saddlp2d:
470 %tmp1 = load <4 x i32>, ptr %A
471 %tmp3 = call <2 x i64> @llvm.aarch64.neon.saddlp.v2i64.v4i32(<4 x i32> %tmp1)
475 declare <4 x i16> @llvm.aarch64.neon.saddlp.v4i16.v8i8(<8 x i8>) nounwind readnone
476 declare <2 x i32> @llvm.aarch64.neon.saddlp.v2i32.v4i16(<4 x i16>) nounwind readnone
477 declare <1 x i64> @llvm.aarch64.neon.saddlp.v1i64.v2i32(<2 x i32>) nounwind readnone
479 declare <8 x i16> @llvm.aarch64.neon.saddlp.v8i16.v16i8(<16 x i8>) nounwind readnone
480 declare <4 x i32> @llvm.aarch64.neon.saddlp.v4i32.v8i16(<8 x i16>) nounwind readnone
481 declare <2 x i64> @llvm.aarch64.neon.saddlp.v2i64.v4i32(<4 x i32>) nounwind readnone
483 define <4 x i16> @uaddlp4h(ptr %A) nounwind {
484 ;CHECK-LABEL: uaddlp4h:
486 %tmp1 = load <8 x i8>, ptr %A
487 %tmp3 = call <4 x i16> @llvm.aarch64.neon.uaddlp.v4i16.v8i8(<8 x i8> %tmp1)
491 define <2 x i32> @uaddlp2s(ptr %A) nounwind {
492 ;CHECK-LABEL: uaddlp2s:
494 %tmp1 = load <4 x i16>, ptr %A
495 %tmp3 = call <2 x i32> @llvm.aarch64.neon.uaddlp.v2i32.v4i16(<4 x i16> %tmp1)
499 define <1 x i64> @uaddlp1d(ptr %A) nounwind {
500 ;CHECK-LABEL: uaddlp1d:
502 %tmp1 = load <2 x i32>, ptr %A
503 %tmp3 = call <1 x i64> @llvm.aarch64.neon.uaddlp.v1i64.v2i32(<2 x i32> %tmp1)
507 define <8 x i16> @uaddlp8h(ptr %A) nounwind {
508 ;CHECK-LABEL: uaddlp8h:
510 %tmp1 = load <16 x i8>, ptr %A
511 %tmp3 = call <8 x i16> @llvm.aarch64.neon.uaddlp.v8i16.v16i8(<16 x i8> %tmp1)
515 define <4 x i32> @uaddlp4s(ptr %A) nounwind {
516 ;CHECK-LABEL: uaddlp4s:
518 %tmp1 = load <8 x i16>, ptr %A
519 %tmp3 = call <4 x i32> @llvm.aarch64.neon.uaddlp.v4i32.v8i16(<8 x i16> %tmp1)
523 define <2 x i64> @uaddlp2d(ptr %A) nounwind {
524 ;CHECK-LABEL: uaddlp2d:
526 %tmp1 = load <4 x i32>, ptr %A
527 %tmp3 = call <2 x i64> @llvm.aarch64.neon.uaddlp.v2i64.v4i32(<4 x i32> %tmp1)
531 declare <4 x i16> @llvm.aarch64.neon.uaddlp.v4i16.v8i8(<8 x i8>) nounwind readnone
532 declare <2 x i32> @llvm.aarch64.neon.uaddlp.v2i32.v4i16(<4 x i16>) nounwind readnone
533 declare <1 x i64> @llvm.aarch64.neon.uaddlp.v1i64.v2i32(<2 x i32>) nounwind readnone
535 declare <8 x i16> @llvm.aarch64.neon.uaddlp.v8i16.v16i8(<16 x i8>) nounwind readnone
536 declare <4 x i32> @llvm.aarch64.neon.uaddlp.v4i32.v8i16(<8 x i16>) nounwind readnone
537 declare <2 x i64> @llvm.aarch64.neon.uaddlp.v2i64.v4i32(<4 x i32>) nounwind readnone
539 define <4 x i16> @sadalp4h(ptr %A, ptr %B) nounwind {
540 ;CHECK-LABEL: sadalp4h:
542 %tmp1 = load <8 x i8>, ptr %A
543 %tmp3 = call <4 x i16> @llvm.aarch64.neon.saddlp.v4i16.v8i8(<8 x i8> %tmp1)
544 %tmp4 = load <4 x i16>, ptr %B
545 %tmp5 = add <4 x i16> %tmp3, %tmp4
549 define <2 x i32> @sadalp2s(ptr %A, ptr %B) nounwind {
550 ;CHECK-LABEL: sadalp2s:
552 %tmp1 = load <4 x i16>, ptr %A
553 %tmp3 = call <2 x i32> @llvm.aarch64.neon.saddlp.v2i32.v4i16(<4 x i16> %tmp1)
554 %tmp4 = load <2 x i32>, ptr %B
555 %tmp5 = add <2 x i32> %tmp3, %tmp4
559 define <8 x i16> @sadalp8h(ptr %A, ptr %B) nounwind {
560 ;CHECK-LABEL: sadalp8h:
562 %tmp1 = load <16 x i8>, ptr %A
563 %tmp3 = call <8 x i16> @llvm.aarch64.neon.saddlp.v8i16.v16i8(<16 x i8> %tmp1)
564 %tmp4 = load <8 x i16>, ptr %B
565 %tmp5 = add <8 x i16> %tmp3, %tmp4
569 define <4 x i32> @sadalp4s(ptr %A, ptr %B) nounwind {
570 ;CHECK-LABEL: sadalp4s:
572 %tmp1 = load <8 x i16>, ptr %A
573 %tmp3 = call <4 x i32> @llvm.aarch64.neon.saddlp.v4i32.v8i16(<8 x i16> %tmp1)
574 %tmp4 = load <4 x i32>, ptr %B
575 %tmp5 = add <4 x i32> %tmp3, %tmp4
579 define <2 x i64> @sadalp2d(ptr %A, ptr %B) nounwind {
580 ;CHECK-LABEL: sadalp2d:
582 %tmp1 = load <4 x i32>, ptr %A
583 %tmp3 = call <2 x i64> @llvm.aarch64.neon.saddlp.v2i64.v4i32(<4 x i32> %tmp1)
584 %tmp4 = load <2 x i64>, ptr %B
585 %tmp5 = add <2 x i64> %tmp3, %tmp4
589 define <4 x i16> @uadalp4h(ptr %A, ptr %B) nounwind {
590 ;CHECK-LABEL: uadalp4h:
592 %tmp1 = load <8 x i8>, ptr %A
593 %tmp3 = call <4 x i16> @llvm.aarch64.neon.uaddlp.v4i16.v8i8(<8 x i8> %tmp1)
594 %tmp4 = load <4 x i16>, ptr %B
595 %tmp5 = add <4 x i16> %tmp3, %tmp4
599 define <2 x i32> @uadalp2s(ptr %A, ptr %B) nounwind {
600 ;CHECK-LABEL: uadalp2s:
602 %tmp1 = load <4 x i16>, ptr %A
603 %tmp3 = call <2 x i32> @llvm.aarch64.neon.uaddlp.v2i32.v4i16(<4 x i16> %tmp1)
604 %tmp4 = load <2 x i32>, ptr %B
605 %tmp5 = add <2 x i32> %tmp3, %tmp4
609 define <8 x i16> @uadalp8h(ptr %A, ptr %B) nounwind {
610 ;CHECK-LABEL: uadalp8h:
612 %tmp1 = load <16 x i8>, ptr %A
613 %tmp3 = call <8 x i16> @llvm.aarch64.neon.uaddlp.v8i16.v16i8(<16 x i8> %tmp1)
614 %tmp4 = load <8 x i16>, ptr %B
615 %tmp5 = add <8 x i16> %tmp3, %tmp4
619 define <4 x i32> @uadalp4s(ptr %A, ptr %B) nounwind {
620 ;CHECK-LABEL: uadalp4s:
622 %tmp1 = load <8 x i16>, ptr %A
623 %tmp3 = call <4 x i32> @llvm.aarch64.neon.uaddlp.v4i32.v8i16(<8 x i16> %tmp1)
624 %tmp4 = load <4 x i32>, ptr %B
625 %tmp5 = add <4 x i32> %tmp3, %tmp4
629 define <2 x i64> @uadalp2d(ptr %A, ptr %B) nounwind {
630 ;CHECK-LABEL: uadalp2d:
632 %tmp1 = load <4 x i32>, ptr %A
633 %tmp3 = call <2 x i64> @llvm.aarch64.neon.uaddlp.v2i64.v4i32(<4 x i32> %tmp1)
634 %tmp4 = load <2 x i64>, ptr %B
635 %tmp5 = add <2 x i64> %tmp3, %tmp4
639 define <8 x i8> @addp_8b(ptr %A, ptr %B) nounwind {
640 ;CHECK-LABEL: addp_8b:
642 %tmp1 = load <8 x i8>, ptr %A
643 %tmp2 = load <8 x i8>, ptr %B
644 %tmp3 = call <8 x i8> @llvm.aarch64.neon.addp.v8i8(<8 x i8> %tmp1, <8 x i8> %tmp2)
648 define <16 x i8> @addp_16b(ptr %A, ptr %B) nounwind {
649 ;CHECK-LABEL: addp_16b:
651 %tmp1 = load <16 x i8>, ptr %A
652 %tmp2 = load <16 x i8>, ptr %B
653 %tmp3 = call <16 x i8> @llvm.aarch64.neon.addp.v16i8(<16 x i8> %tmp1, <16 x i8> %tmp2)
657 define <4 x i16> @addp_4h(ptr %A, ptr %B) nounwind {
658 ;CHECK-LABEL: addp_4h:
660 %tmp1 = load <4 x i16>, ptr %A
661 %tmp2 = load <4 x i16>, ptr %B
662 %tmp3 = call <4 x i16> @llvm.aarch64.neon.addp.v4i16(<4 x i16> %tmp1, <4 x i16> %tmp2)
666 define <8 x i16> @addp_8h(ptr %A, ptr %B) nounwind {
667 ;CHECK-LABEL: addp_8h:
669 %tmp1 = load <8 x i16>, ptr %A
670 %tmp2 = load <8 x i16>, ptr %B
671 %tmp3 = call <8 x i16> @llvm.aarch64.neon.addp.v8i16(<8 x i16> %tmp1, <8 x i16> %tmp2)
675 define <2 x i32> @addp_2s(ptr %A, ptr %B) nounwind {
676 ;CHECK-LABEL: addp_2s:
678 %tmp1 = load <2 x i32>, ptr %A
679 %tmp2 = load <2 x i32>, ptr %B
680 %tmp3 = call <2 x i32> @llvm.aarch64.neon.addp.v2i32(<2 x i32> %tmp1, <2 x i32> %tmp2)
684 define <4 x i32> @addp_4s(ptr %A, ptr %B) nounwind {
685 ;CHECK-LABEL: addp_4s:
687 %tmp1 = load <4 x i32>, ptr %A
688 %tmp2 = load <4 x i32>, ptr %B
689 %tmp3 = call <4 x i32> @llvm.aarch64.neon.addp.v4i32(<4 x i32> %tmp1, <4 x i32> %tmp2)
693 define <2 x i64> @addp_2d(ptr %A, ptr %B) nounwind {
694 ;CHECK-LABEL: addp_2d:
696 %tmp1 = load <2 x i64>, ptr %A
697 %tmp2 = load <2 x i64>, ptr %B
698 %tmp3 = call <2 x i64> @llvm.aarch64.neon.addp.v2i64(<2 x i64> %tmp1, <2 x i64> %tmp2)
702 declare <8 x i8> @llvm.aarch64.neon.addp.v8i8(<8 x i8>, <8 x i8>) nounwind readnone
703 declare <16 x i8> @llvm.aarch64.neon.addp.v16i8(<16 x i8>, <16 x i8>) nounwind readnone
704 declare <4 x i16> @llvm.aarch64.neon.addp.v4i16(<4 x i16>, <4 x i16>) nounwind readnone
705 declare <8 x i16> @llvm.aarch64.neon.addp.v8i16(<8 x i16>, <8 x i16>) nounwind readnone
706 declare <2 x i32> @llvm.aarch64.neon.addp.v2i32(<2 x i32>, <2 x i32>) nounwind readnone
707 declare <4 x i32> @llvm.aarch64.neon.addp.v4i32(<4 x i32>, <4 x i32>) nounwind readnone
708 declare <2 x i64> @llvm.aarch64.neon.addp.v2i64(<2 x i64>, <2 x i64>) nounwind readnone
710 define <2 x float> @faddp_2s(ptr %A, ptr %B) nounwind {
711 ;CHECK-LABEL: faddp_2s:
713 %tmp1 = load <2 x float>, ptr %A
714 %tmp2 = load <2 x float>, ptr %B
715 %tmp3 = call <2 x float> @llvm.aarch64.neon.faddp.v2f32(<2 x float> %tmp1, <2 x float> %tmp2)
716 ret <2 x float> %tmp3
719 define <4 x float> @faddp_4s(ptr %A, ptr %B) nounwind {
720 ;CHECK-LABEL: faddp_4s:
722 %tmp1 = load <4 x float>, ptr %A
723 %tmp2 = load <4 x float>, ptr %B
724 %tmp3 = call <4 x float> @llvm.aarch64.neon.faddp.v4f32(<4 x float> %tmp1, <4 x float> %tmp2)
725 ret <4 x float> %tmp3
728 define <2 x double> @faddp_2d(ptr %A, ptr %B) nounwind {
729 ;CHECK-LABEL: faddp_2d:
731 %tmp1 = load <2 x double>, ptr %A
732 %tmp2 = load <2 x double>, ptr %B
733 %tmp3 = call <2 x double> @llvm.aarch64.neon.faddp.v2f64(<2 x double> %tmp1, <2 x double> %tmp2)
734 ret <2 x double> %tmp3
737 declare <2 x float> @llvm.aarch64.neon.faddp.v2f32(<2 x float>, <2 x float>) nounwind readnone
738 declare <4 x float> @llvm.aarch64.neon.faddp.v4f32(<4 x float>, <4 x float>) nounwind readnone
739 declare <2 x double> @llvm.aarch64.neon.faddp.v2f64(<2 x double>, <2 x double>) nounwind readnone
741 define <2 x i64> @uaddl_duprhs(<4 x i32> %lhs, i32 %rhs) {
742 ; CHECK-LABEL: uaddl_duprhs
745 %rhsvec.tmp = insertelement <2 x i32> undef, i32 %rhs, i32 0
746 %rhsvec = insertelement <2 x i32> %rhsvec.tmp, i32 %rhs, i32 1
748 %lhs.high = shufflevector <4 x i32> %lhs, <4 x i32> undef, <2 x i32> <i32 0, i32 1>
750 %lhs.ext = zext <2 x i32> %lhs.high to <2 x i64>
751 %rhs.ext = zext <2 x i32> %rhsvec to <2 x i64>
753 %res = add <2 x i64> %lhs.ext, %rhs.ext
757 define <2 x i64> @uaddl2_duprhs(<4 x i32> %lhs, i32 %rhs) {
758 ; CHECK-LABEL: uaddl2_duprhs
761 %rhsvec.tmp = insertelement <2 x i32> undef, i32 %rhs, i32 0
762 %rhsvec = insertelement <2 x i32> %rhsvec.tmp, i32 %rhs, i32 1
764 %lhs.high = shufflevector <4 x i32> %lhs, <4 x i32> undef, <2 x i32> <i32 2, i32 3>
766 %lhs.ext = zext <2 x i32> %lhs.high to <2 x i64>
767 %rhs.ext = zext <2 x i32> %rhsvec to <2 x i64>
769 %res = add <2 x i64> %lhs.ext, %rhs.ext
773 define <2 x i64> @saddl_duplhs(i32 %lhs, <4 x i32> %rhs) {
774 ; CHECK-LABEL: saddl_duplhs
777 %lhsvec.tmp = insertelement <2 x i32> undef, i32 %lhs, i32 0
778 %lhsvec = insertelement <2 x i32> %lhsvec.tmp, i32 %lhs, i32 1
780 %rhs.high = shufflevector <4 x i32> %rhs, <4 x i32> undef, <2 x i32> <i32 0, i32 1>
782 %lhs.ext = sext <2 x i32> %lhsvec to <2 x i64>
783 %rhs.ext = sext <2 x i32> %rhs.high to <2 x i64>
785 %res = add <2 x i64> %lhs.ext, %rhs.ext
789 define <2 x i64> @saddl2_duplhs(i32 %lhs, <4 x i32> %rhs) {
790 ; CHECK-LABEL: saddl2_duplhs
793 %lhsvec.tmp = insertelement <2 x i32> undef, i32 %lhs, i32 0
794 %lhsvec = insertelement <2 x i32> %lhsvec.tmp, i32 %lhs, i32 1
796 %rhs.high = shufflevector <4 x i32> %rhs, <4 x i32> undef, <2 x i32> <i32 2, i32 3>
798 %lhs.ext = sext <2 x i32> %lhsvec to <2 x i64>
799 %rhs.ext = sext <2 x i32> %rhs.high to <2 x i64>
801 %res = add <2 x i64> %lhs.ext, %rhs.ext
805 define <2 x i64> @usubl_duprhs(<4 x i32> %lhs, i32 %rhs) {
806 ; CHECK-LABEL: usubl_duprhs
809 %rhsvec.tmp = insertelement <2 x i32> undef, i32 %rhs, i32 0
810 %rhsvec = insertelement <2 x i32> %rhsvec.tmp, i32 %rhs, i32 1
812 %lhs.high = shufflevector <4 x i32> %lhs, <4 x i32> undef, <2 x i32> <i32 0, i32 1>
814 %lhs.ext = zext <2 x i32> %lhs.high to <2 x i64>
815 %rhs.ext = zext <2 x i32> %rhsvec to <2 x i64>
817 %res = sub <2 x i64> %lhs.ext, %rhs.ext
821 define <2 x i64> @usubl2_duprhs(<4 x i32> %lhs, i32 %rhs) {
822 ; CHECK-LABEL: usubl2_duprhs
825 %rhsvec.tmp = insertelement <2 x i32> undef, i32 %rhs, i32 0
826 %rhsvec = insertelement <2 x i32> %rhsvec.tmp, i32 %rhs, i32 1
828 %lhs.high = shufflevector <4 x i32> %lhs, <4 x i32> undef, <2 x i32> <i32 2, i32 3>
830 %lhs.ext = zext <2 x i32> %lhs.high to <2 x i64>
831 %rhs.ext = zext <2 x i32> %rhsvec to <2 x i64>
833 %res = sub <2 x i64> %lhs.ext, %rhs.ext
837 define <2 x i64> @ssubl_duplhs(i32 %lhs, <4 x i32> %rhs) {
838 ; CHECK-LABEL: ssubl_duplhs:
841 %lhsvec.tmp = insertelement <2 x i32> undef, i32 %lhs, i32 0
842 %lhsvec = insertelement <2 x i32> %lhsvec.tmp, i32 %lhs, i32 1
844 %rhs.high = shufflevector <4 x i32> %rhs, <4 x i32> undef, <2 x i32> <i32 0, i32 1>
846 %lhs.ext = sext <2 x i32> %lhsvec to <2 x i64>
847 %rhs.ext = sext <2 x i32> %rhs.high to <2 x i64>
849 %res = sub <2 x i64> %lhs.ext, %rhs.ext
853 define <2 x i64> @ssubl2_duplhs(i32 %lhs, <4 x i32> %rhs) {
854 ; CHECK-LABEL: ssubl2_duplhs:
857 %lhsvec.tmp = insertelement <2 x i32> undef, i32 %lhs, i32 0
858 %lhsvec = insertelement <2 x i32> %lhsvec.tmp, i32 %lhs, i32 1
860 %rhs.high = shufflevector <4 x i32> %rhs, <4 x i32> undef, <2 x i32> <i32 2, i32 3>
862 %lhs.ext = sext <2 x i32> %lhsvec to <2 x i64>
863 %rhs.ext = sext <2 x i32> %rhs.high to <2 x i64>
865 %res = sub <2 x i64> %lhs.ext, %rhs.ext
869 define <8 x i8> @addhn8b_natural(ptr %A, ptr %B) nounwind {
870 ;CHECK-LABEL: addhn8b_natural:
872 %tmp1 = load <8 x i16>, ptr %A
873 %tmp2 = load <8 x i16>, ptr %B
874 %sum = add <8 x i16> %tmp1, %tmp2
875 %high_bits = lshr <8 x i16> %sum, <i16 8, i16 8, i16 8, i16 8, i16 8, i16 8, i16 8, i16 8>
876 %narrowed = trunc <8 x i16> %high_bits to <8 x i8>
877 ret <8 x i8> %narrowed
880 define <4 x i16> @addhn4h_natural(ptr %A, ptr %B) nounwind {
881 ;CHECK-LABEL: addhn4h_natural:
883 %tmp1 = load <4 x i32>, ptr %A
884 %tmp2 = load <4 x i32>, ptr %B
885 %sum = add <4 x i32> %tmp1, %tmp2
886 %high_bits = lshr <4 x i32> %sum, <i32 16, i32 16, i32 16, i32 16>
887 %narrowed = trunc <4 x i32> %high_bits to <4 x i16>
888 ret <4 x i16> %narrowed
891 define <2 x i32> @addhn2s_natural(ptr %A, ptr %B) nounwind {
892 ;CHECK-LABEL: addhn2s_natural:
894 %tmp1 = load <2 x i64>, ptr %A
895 %tmp2 = load <2 x i64>, ptr %B
896 %sum = add <2 x i64> %tmp1, %tmp2
897 %high_bits = lshr <2 x i64> %sum, <i64 32, i64 32>
898 %narrowed = trunc <2 x i64> %high_bits to <2 x i32>
899 ret <2 x i32> %narrowed
902 define <16 x i8> @addhn2_16b_natural(<8 x i8> %low, ptr %A, ptr %B) nounwind {
903 ;CHECK-LABEL: addhn2_16b_natural:
905 %tmp1 = load <8 x i16>, ptr %A
906 %tmp2 = load <8 x i16>, ptr %B
907 %sum = add <8 x i16> %tmp1, %tmp2
908 %high_bits = lshr <8 x i16> %sum, <i16 8, i16 8, i16 8, i16 8, i16 8, i16 8, i16 8, i16 8>
909 %narrowed = trunc <8 x i16> %high_bits to <8 x i8>
910 %res = shufflevector <8 x i8> %low, <8 x i8> %narrowed, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15>
914 define <8 x i16> @addhn2_8h_natural(<4 x i16> %low, ptr %A, ptr %B) nounwind {
915 ;CHECK-LABEL: addhn2_8h_natural:
917 %tmp1 = load <4 x i32>, ptr %A
918 %tmp2 = load <4 x i32>, ptr %B
919 %sum = add <4 x i32> %tmp1, %tmp2
920 %high_bits = lshr <4 x i32> %sum, <i32 16, i32 16, i32 16, i32 16>
921 %narrowed = trunc <4 x i32> %high_bits to <4 x i16>
922 %res = shufflevector <4 x i16> %low, <4 x i16> %narrowed, <8 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7>
926 define <4 x i32> @addhn2_4s_natural(<2 x i32> %low, ptr %A, ptr %B) nounwind {
927 ;CHECK-LABEL: addhn2_4s_natural:
929 %tmp1 = load <2 x i64>, ptr %A
930 %tmp2 = load <2 x i64>, ptr %B
931 %sum = add <2 x i64> %tmp1, %tmp2
932 %high_bits = lshr <2 x i64> %sum, <i64 32, i64 32>
933 %narrowed = trunc <2 x i64> %high_bits to <2 x i32>
934 %res = shufflevector <2 x i32> %low, <2 x i32> %narrowed, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
938 define <4 x i32> @addhn_addhn2_4s(ptr %A, ptr %B, ptr %C, ptr %D) nounwind {
939 ;CHECK-LABEL: addhn_addhn2_4s
943 %tmp1 = load <2 x i64>, ptr %A
944 %tmp2 = load <2 x i64>, ptr %B
945 %sum1 = add <2 x i64> %tmp1, %tmp2
946 %low_bits = lshr <2 x i64> %sum1, <i64 32, i64 32>
947 %narrowed1 = trunc <2 x i64> %low_bits to <2 x i32>
948 %tmp3 = load <2 x i64>, ptr %C
949 %tmp4 = load <2 x i64>, ptr %D
950 %sum2 = add <2 x i64> %tmp3, %tmp4
951 %high_bits = lshr <2 x i64> %sum1, <i64 32, i64 32>
952 %narrowed2 = trunc <2 x i64> %high_bits to <2 x i32>
953 %res = shufflevector <2 x i32> %narrowed1, <2 x i32> %narrowed2, <4 x i32> <i32 0, i32 1, i32 2, i32 3>
957 define <8 x i8> @subhn8b_natural(ptr %A, ptr %B) nounwind {
958 ;CHECK-LABEL: subhn8b_natural:
960 %tmp1 = load <8 x i16>, ptr %A
961 %tmp2 = load <8 x i16>, ptr %B
962 %diff = sub <8 x i16> %tmp1, %tmp2
963 %high_bits = lshr <8 x i16> %diff, <i16 8, i16 8, i16 8, i16 8, i16 8, i16 8, i16 8, i16 8>
964 %narrowed = trunc <8 x i16> %high_bits to <8 x i8>
965 ret <8 x i8> %narrowed
968 define <4 x i16> @subhn4h_natural(ptr %A, ptr %B) nounwind {
969 ;CHECK-LABEL: subhn4h_natural:
971 %tmp1 = load <4 x i32>, ptr %A
972 %tmp2 = load <4 x i32>, ptr %B
973 %diff = sub <4 x i32> %tmp1, %tmp2
974 %high_bits = lshr <4 x i32> %diff, <i32 16, i32 16, i32 16, i32 16>
975 %narrowed = trunc <4 x i32> %high_bits to <4 x i16>
976 ret <4 x i16> %narrowed
979 define <2 x i32> @subhn2s_natural(ptr %A, ptr %B) nounwind {
980 ;CHECK-LABEL: subhn2s_natural:
982 %tmp1 = load <2 x i64>, ptr %A
983 %tmp2 = load <2 x i64>, ptr %B
984 %diff = sub <2 x i64> %tmp1, %tmp2
985 %high_bits = lshr <2 x i64> %diff, <i64 32, i64 32>
986 %narrowed = trunc <2 x i64> %high_bits to <2 x i32>
987 ret <2 x i32> %narrowed
990 define <16 x i8> @subhn2_16b_natural(<8 x i8> %low, ptr %A, ptr %B) nounwind {
991 ;CHECK-LABEL: subhn2_16b_natural:
993 %tmp1 = load <8 x i16>, ptr %A
994 %tmp2 = load <8 x i16>, ptr %B
995 %diff = sub <8 x i16> %tmp1, %tmp2
996 %high_bits = lshr <8 x i16> %diff, <i16 8, i16 8, i16 8, i16 8, i16 8, i16 8, i16 8, i16 8>
997 %narrowed = trunc <8 x i16> %high_bits to <8 x i8>
998 %res = shufflevector <8 x i8> %low, <8 x i8> %narrowed, <16 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7, i32 8, i32 9, i32 10, i32 11, i32 12, i32 13, i32 14, i32 15>
1002 define <8 x i16> @subhn2_8h_natural(<4 x i16> %low, ptr %A, ptr %B) nounwind {
1003 ;CHECK-LABEL: subhn2_8h_natural:
1005 %tmp1 = load <4 x i32>, ptr %A
1006 %tmp2 = load <4 x i32>, ptr %B
1007 %diff = sub <4 x i32> %tmp1, %tmp2
1008 %high_bits = lshr <4 x i32> %diff, <i32 16, i32 16, i32 16, i32 16>
1009 %narrowed = trunc <4 x i32> %high_bits to <4 x i16>
1010 %res = shufflevector <4 x i16> %low, <4 x i16> %narrowed, <8 x i32> <i32 0, i32 1, i32 2, i32 3, i32 4, i32 5, i32 6, i32 7>
1014 define <4 x i32> @subhn2_4s_natural(<2 x i32> %low, ptr %A, ptr %B) nounwind {
1015 ;CHECK-LABEL: subhn2_4s_natural:
1017 %tmp1 = load <2 x i64>, ptr %A
1018 %tmp2 = load <2 x i64>, ptr %B
1019 %diff = sub <2 x i64> %tmp1, %tmp2
1020 %high_bits = lshr <2 x i64> %diff, <i64 32, i64 32>
1021 %narrowed = trunc <2 x i64> %high_bits to <2 x i32>
1022 %res = shufflevector <2 x i32> %low, <2 x i32> %narrowed, <4 x i32> <i32 0, i32 1, i32 2, i32 3>