1; RUN: llc < %s -march=arm64 -aarch64-neon-syntax=apple | FileCheck %s
2
3; CHECK: autogen_SD19655
4; CHECK: scvtf
5; CHECK: ret
6define void @autogen_SD19655(<2 x i64>* %addr, <2 x float>* %addrfloat) {
7  %T = load <2 x i64>, <2 x i64>* %addr
8  %F = sitofp <2 x i64> %T to <2 x float>
9  store <2 x float> %F, <2 x float>* %addrfloat
10  ret void
11}
12
13define <2 x double> @test_signed_v2i32_to_v2f64(<2 x i32> %v) nounwind readnone {
14; CHECK-LABEL: test_signed_v2i32_to_v2f64:
15; CHECK: sshll.2d [[VAL64:v[0-9]+]], v0, #0
16; CHECK-NEXT: scvtf.2d v0, [[VAL64]]
17; CHECK-NEXT: ret
18  %conv = sitofp <2 x i32> %v to <2 x double>
19  ret <2 x double> %conv
20}
21
22define <2 x double> @test_unsigned_v2i32_to_v2f64(<2 x i32> %v) nounwind readnone {
23; CHECK-LABEL: test_unsigned_v2i32_to_v2f64
24; CHECK: ushll.2d [[VAL64:v[0-9]+]], v0, #0
25; CHECK-NEXT: ucvtf.2d v0, [[VAL64]]
26; CHECK-NEXT: ret
27  %conv = uitofp <2 x i32> %v to <2 x double>
28  ret <2 x double> %conv
29}
30
31define <2 x double> @test_signed_v2i16_to_v2f64(<2 x i16> %v) nounwind readnone {
32; CHECK-LABEL: test_signed_v2i16_to_v2f64:
33; CHECK: shl.2s [[TMP:v[0-9]+]], v0, #16
34; CHECK: sshr.2s [[VAL32:v[0-9]+]], [[TMP]], #16
35; CHECK: sshll.2d [[VAL64:v[0-9]+]], [[VAL32]], #0
36; CHECK: scvtf.2d v0, [[VAL64]]
37
38  %conv = sitofp <2 x i16> %v to <2 x double>
39  ret <2 x double> %conv
40}
41define <2 x double> @test_unsigned_v2i16_to_v2f64(<2 x i16> %v) nounwind readnone {
42; CHECK-LABEL: test_unsigned_v2i16_to_v2f64
43; CHECK: movi d[[MASK:[0-9]+]], #0x00ffff0000ffff
44; CHECK: and.8b [[VAL32:v[0-9]+]], v0, v[[MASK]]
45; CHECK: ushll.2d [[VAL64:v[0-9]+]], [[VAL32]], #0
46; CHECK: ucvtf.2d v0, [[VAL64]]
47
48  %conv = uitofp <2 x i16> %v to <2 x double>
49  ret <2 x double> %conv
50}
51
52define <2 x double> @test_signed_v2i8_to_v2f64(<2 x i8> %v) nounwind readnone {
53; CHECK-LABEL: test_signed_v2i8_to_v2f64:
54; CHECK: shl.2s [[TMP:v[0-9]+]], v0, #24
55; CHECK: sshr.2s [[VAL32:v[0-9]+]], [[TMP]], #24
56; CHECK: sshll.2d [[VAL64:v[0-9]+]], [[VAL32]], #0
57; CHECK: scvtf.2d v0, [[VAL64]]
58
59  %conv = sitofp <2 x i8> %v to <2 x double>
60  ret <2 x double> %conv
61}
62define <2 x double> @test_unsigned_v2i8_to_v2f64(<2 x i8> %v) nounwind readnone {
63; CHECK-LABEL: test_unsigned_v2i8_to_v2f64
64; CHECK: movi d[[MASK:[0-9]+]], #0x0000ff000000ff
65; CHECK: and.8b [[VAL32:v[0-9]+]], v0, v[[MASK]]
66; CHECK: ushll.2d [[VAL64:v[0-9]+]], [[VAL32]], #0
67; CHECK: ucvtf.2d v0, [[VAL64]]
68
69  %conv = uitofp <2 x i8> %v to <2 x double>
70  ret <2 x double> %conv
71}
72
73define <2 x float> @test_signed_v2i64_to_v2f32(<2 x i64> %v) nounwind readnone {
74; CHECK-LABEL: test_signed_v2i64_to_v2f32:
75; CHECK: scvtf.2d [[VAL64:v[0-9]+]], v0
76; CHECK: fcvtn v0.2s, [[VAL64]].2d
77
78  %conv = sitofp <2 x i64> %v to <2 x float>
79  ret <2 x float> %conv
80}
81define <2 x float> @test_unsigned_v2i64_to_v2f32(<2 x i64> %v) nounwind readnone {
82; CHECK-LABEL: test_unsigned_v2i64_to_v2f32
83; CHECK: ucvtf.2d [[VAL64:v[0-9]+]], v0
84; CHECK: fcvtn v0.2s, [[VAL64]].2d
85
86  %conv = uitofp <2 x i64> %v to <2 x float>
87  ret <2 x float> %conv
88}
89
90define <2 x float> @test_signed_v2i16_to_v2f32(<2 x i16> %v) nounwind readnone {
91; CHECK-LABEL: test_signed_v2i16_to_v2f32:
92; CHECK: shl.2s [[TMP:v[0-9]+]], v0, #16
93; CHECK: sshr.2s [[VAL32:v[0-9]+]], [[TMP]], #16
94; CHECK: scvtf.2s v0, [[VAL32]]
95
96  %conv = sitofp <2 x i16> %v to <2 x float>
97  ret <2 x float> %conv
98}
99define <2 x float> @test_unsigned_v2i16_to_v2f32(<2 x i16> %v) nounwind readnone {
100; CHECK-LABEL: test_unsigned_v2i16_to_v2f32
101; CHECK: movi d[[MASK:[0-9]+]], #0x00ffff0000ffff
102; CHECK: and.8b [[VAL32:v[0-9]+]], v0, v[[MASK]]
103; CHECK: ucvtf.2s v0, [[VAL32]]
104
105  %conv = uitofp <2 x i16> %v to <2 x float>
106  ret <2 x float> %conv
107}
108
109define <2 x float> @test_signed_v2i8_to_v2f32(<2 x i8> %v) nounwind readnone {
110; CHECK-LABEL: test_signed_v2i8_to_v2f32:
111; CHECK: shl.2s [[TMP:v[0-9]+]], v0, #24
112; CHECK: sshr.2s [[VAL32:v[0-9]+]], [[TMP]], #24
113; CHECK: scvtf.2s v0, [[VAL32]]
114
115  %conv = sitofp <2 x i8> %v to <2 x float>
116  ret <2 x float> %conv
117}
118define <2 x float> @test_unsigned_v2i8_to_v2f32(<2 x i8> %v) nounwind readnone {
119; CHECK-LABEL: test_unsigned_v2i8_to_v2f32
120; CHECK: movi d[[MASK:[0-9]+]], #0x0000ff000000ff
121; CHECK: and.8b [[VAL32:v[0-9]+]], v0, v[[MASK]]
122; CHECK: ucvtf.2s v0, [[VAL32]]
123
124  %conv = uitofp <2 x i8> %v to <2 x float>
125  ret <2 x float> %conv
126}
127
128define <4 x float> @test_signed_v4i16_to_v4f32(<4 x i16> %v) nounwind readnone {
129; CHECK-LABEL: test_signed_v4i16_to_v4f32:
130; CHECK: sshll.4s [[VAL32:v[0-9]+]], v0, #0
131; CHECK: scvtf.4s v0, [[VAL32]]
132
133  %conv = sitofp <4 x i16> %v to <4 x float>
134  ret <4 x float> %conv
135}
136
137define <4 x float> @test_unsigned_v4i16_to_v4f32(<4 x i16> %v) nounwind readnone {
138; CHECK-LABEL: test_unsigned_v4i16_to_v4f32
139; CHECK: ushll.4s [[VAL32:v[0-9]+]], v0, #0
140; CHECK: ucvtf.4s v0, [[VAL32]]
141
142  %conv = uitofp <4 x i16> %v to <4 x float>
143  ret <4 x float> %conv
144}
145
146define <4 x float> @test_signed_v4i8_to_v4f32(<4 x i8> %v) nounwind readnone {
147; CHECK-LABEL: test_signed_v4i8_to_v4f32:
148; CHECK: shl.4h [[TMP:v[0-9]+]], v0, #8
149; CHECK: sshr.4h [[VAL16:v[0-9]+]], [[TMP]], #8
150; CHECK: sshll.4s [[VAL32:v[0-9]+]], [[VAL16]], #0
151; CHECK: scvtf.4s v0, [[VAL32]]
152
153  %conv = sitofp <4 x i8> %v to <4 x float>
154  ret <4 x float> %conv
155}
156define <4 x float> @test_unsigned_v4i8_to_v4f32(<4 x i8> %v) nounwind readnone {
157; CHECK-LABEL: test_unsigned_v4i8_to_v4f32
158; CHECK: bic.4h v0, #255, lsl #8
159; CHECK: ushll.4s [[VAL32:v[0-9]+]], v0, #0
160; CHECK: ucvtf.4s v0, [[VAL32]]
161
162  %conv = uitofp <4 x i8> %v to <4 x float>
163  ret <4 x float> %conv
164}
165