1 ; RUN: llc -mtriple=aarch64-none-linux-gnu -mattr=+neon < %s | FileCheck %s
2 ; intrinsic wrangling that arm64 does differently.
4 define i8 @test_vqmovunh_s16(i16 %a) {
5 ; CHECK: test_vqmovunh_s16
6 ; CHECK: sqxtun {{b[0-9]+}}, {{h[0-9]+}}
8 %vqmovun.i = insertelement <1 x i16> undef, i16 %a, i32 0
9 %vqmovun1.i = call <1 x i8> @llvm.arm.neon.vqmovnsu.v1i8(<1 x i16> %vqmovun.i)
10 %0 = extractelement <1 x i8> %vqmovun1.i, i32 0
14 define i16 @test_vqmovuns_s32(i32 %a) {
15 ; CHECK: test_vqmovuns_s32
16 ; CHECK: sqxtun {{h[0-9]+}}, {{s[0-9]+}}
18 %vqmovun.i = insertelement <1 x i32> undef, i32 %a, i32 0
19 %vqmovun1.i = call <1 x i16> @llvm.arm.neon.vqmovnsu.v1i16(<1 x i32> %vqmovun.i)
20 %0 = extractelement <1 x i16> %vqmovun1.i, i32 0
24 define i32 @test_vqmovund_s64(i64 %a) {
25 ; CHECK: test_vqmovund_s64
26 ; CHECK: sqxtun {{s[0-9]+}}, {{d[0-9]+}}
28 %vqmovun.i = insertelement <1 x i64> undef, i64 %a, i32 0
29 %vqmovun1.i = call <1 x i32> @llvm.arm.neon.vqmovnsu.v1i32(<1 x i64> %vqmovun.i)
30 %0 = extractelement <1 x i32> %vqmovun1.i, i32 0
34 declare <1 x i8> @llvm.arm.neon.vqmovnsu.v1i8(<1 x i16>)
35 declare <1 x i16> @llvm.arm.neon.vqmovnsu.v1i16(<1 x i32>)
36 declare <1 x i32> @llvm.arm.neon.vqmovnsu.v1i32(<1 x i64>)
38 define i8 @test_vqmovnh_s16(i16 %a) {
39 ; CHECK: test_vqmovnh_s16
40 ; CHECK: sqxtn {{b[0-9]+}}, {{h[0-9]+}}
42 %vqmovn.i = insertelement <1 x i16> undef, i16 %a, i32 0
43 %vqmovn1.i = call <1 x i8> @llvm.arm.neon.vqmovns.v1i8(<1 x i16> %vqmovn.i)
44 %0 = extractelement <1 x i8> %vqmovn1.i, i32 0
48 define i16 @test_vqmovns_s32(i32 %a) {
49 ; CHECK: test_vqmovns_s32
50 ; CHECK: sqxtn {{h[0-9]+}}, {{s[0-9]+}}
52 %vqmovn.i = insertelement <1 x i32> undef, i32 %a, i32 0
53 %vqmovn1.i = call <1 x i16> @llvm.arm.neon.vqmovns.v1i16(<1 x i32> %vqmovn.i)
54 %0 = extractelement <1 x i16> %vqmovn1.i, i32 0
58 define i32 @test_vqmovnd_s64(i64 %a) {
59 ; CHECK: test_vqmovnd_s64
60 ; CHECK: sqxtn {{s[0-9]+}}, {{d[0-9]+}}
62 %vqmovn.i = insertelement <1 x i64> undef, i64 %a, i32 0
63 %vqmovn1.i = call <1 x i32> @llvm.arm.neon.vqmovns.v1i32(<1 x i64> %vqmovn.i)
64 %0 = extractelement <1 x i32> %vqmovn1.i, i32 0
68 declare <1 x i8> @llvm.arm.neon.vqmovns.v1i8(<1 x i16>)
69 declare <1 x i16> @llvm.arm.neon.vqmovns.v1i16(<1 x i32>)
70 declare <1 x i32> @llvm.arm.neon.vqmovns.v1i32(<1 x i64>)
72 define i8 @test_vqmovnh_u16(i16 %a) {
73 ; CHECK: test_vqmovnh_u16
74 ; CHECK: uqxtn {{b[0-9]+}}, {{h[0-9]+}}
76 %vqmovn.i = insertelement <1 x i16> undef, i16 %a, i32 0
77 %vqmovn1.i = call <1 x i8> @llvm.arm.neon.vqmovnu.v1i8(<1 x i16> %vqmovn.i)
78 %0 = extractelement <1 x i8> %vqmovn1.i, i32 0
83 define i16 @test_vqmovns_u32(i32 %a) {
84 ; CHECK: test_vqmovns_u32
85 ; CHECK: uqxtn {{h[0-9]+}}, {{s[0-9]+}}
87 %vqmovn.i = insertelement <1 x i32> undef, i32 %a, i32 0
88 %vqmovn1.i = call <1 x i16> @llvm.arm.neon.vqmovnu.v1i16(<1 x i32> %vqmovn.i)
89 %0 = extractelement <1 x i16> %vqmovn1.i, i32 0
93 define i32 @test_vqmovnd_u64(i64 %a) {
94 ; CHECK: test_vqmovnd_u64
95 ; CHECK: uqxtn {{s[0-9]+}}, {{d[0-9]+}}
97 %vqmovn.i = insertelement <1 x i64> undef, i64 %a, i32 0
98 %vqmovn1.i = call <1 x i32> @llvm.arm.neon.vqmovnu.v1i32(<1 x i64> %vqmovn.i)
99 %0 = extractelement <1 x i32> %vqmovn1.i, i32 0
103 declare <1 x i8> @llvm.arm.neon.vqmovnu.v1i8(<1 x i16>)
104 declare <1 x i16> @llvm.arm.neon.vqmovnu.v1i16(<1 x i32>)
105 declare <1 x i32> @llvm.arm.neon.vqmovnu.v1i32(<1 x i64>)