Run DCE after a LoopFlatten test to reduce spurious output [nfc]
[llvm-project.git] / llvm / test / CodeGen / ARM / vcvt-v8.ll
blob8bcb633f8d1cfd466fc56d307f3be067971ee750
1 ; RUN: llc < %s -mtriple=armv8 -mattr=+neon | FileCheck %s
2 define <4 x i32> @vcvtasq(ptr %A) {
3 ; CHECK: vcvtasq
4 ; CHECK: vcvta.s32.f32 q{{[0-9]+}}, q{{[0-9]+}}
5   %tmp1 = load <4 x float>, ptr %A
6   %tmp2 = call <4 x i32> @llvm.arm.neon.vcvtas.v4i32.v4f32(<4 x float> %tmp1)
7   ret <4 x i32> %tmp2
10 define <2 x i32> @vcvtasd(ptr %A) {
11 ; CHECK: vcvtasd
12 ; CHECK: vcvta.s32.f32 d{{[0-9]+}}, d{{[0-9]+}}
13   %tmp1 = load <2 x float>, ptr %A
14   %tmp2 = call <2 x i32> @llvm.arm.neon.vcvtas.v2i32.v2f32(<2 x float> %tmp1)
15   ret <2 x i32> %tmp2
18 define <4 x i32> @vcvtnsq(ptr %A) {
19 ; CHECK: vcvtnsq
20 ; CHECK: vcvtn.s32.f32 q{{[0-9]+}}, q{{[0-9]+}}
21   %tmp1 = load <4 x float>, ptr %A
22   %tmp2 = call <4 x i32> @llvm.arm.neon.vcvtns.v4i32.v4f32(<4 x float> %tmp1)
23   ret <4 x i32> %tmp2
26 define <2 x i32> @vcvtnsd(ptr %A) {
27 ; CHECK: vcvtnsd
28 ; CHECK: vcvtn.s32.f32 d{{[0-9]+}}, d{{[0-9]+}}
29   %tmp1 = load <2 x float>, ptr %A
30   %tmp2 = call <2 x i32> @llvm.arm.neon.vcvtns.v2i32.v2f32(<2 x float> %tmp1)
31   ret <2 x i32> %tmp2
34 define <4 x i32> @vcvtpsq(ptr %A) {
35 ; CHECK: vcvtpsq
36 ; CHECK: vcvtp.s32.f32 q{{[0-9]+}}, q{{[0-9]+}}
37   %tmp1 = load <4 x float>, ptr %A
38   %tmp2 = call <4 x i32> @llvm.arm.neon.vcvtps.v4i32.v4f32(<4 x float> %tmp1)
39   ret <4 x i32> %tmp2
42 define <2 x i32> @vcvtpsd(ptr %A) {
43 ; CHECK: vcvtpsd
44 ; CHECK: vcvtp.s32.f32 d{{[0-9]+}}, d{{[0-9]+}}
45   %tmp1 = load <2 x float>, ptr %A
46   %tmp2 = call <2 x i32> @llvm.arm.neon.vcvtps.v2i32.v2f32(<2 x float> %tmp1)
47   ret <2 x i32> %tmp2
50 define <4 x i32> @vcvtmsq(ptr %A) {
51 ; CHECK: vcvtmsq
52 ; CHECK: vcvtm.s32.f32 q{{[0-9]+}}, q{{[0-9]+}}
53   %tmp1 = load <4 x float>, ptr %A
54   %tmp2 = call <4 x i32> @llvm.arm.neon.vcvtms.v4i32.v4f32(<4 x float> %tmp1)
55   ret <4 x i32> %tmp2
58 define <2 x i32> @vcvtmsd(ptr %A) {
59 ; CHECK: vcvtmsd
60 ; CHECK: vcvtm.s32.f32 d{{[0-9]+}}, d{{[0-9]+}}
61   %tmp1 = load <2 x float>, ptr %A
62   %tmp2 = call <2 x i32> @llvm.arm.neon.vcvtms.v2i32.v2f32(<2 x float> %tmp1)
63   ret <2 x i32> %tmp2
66 define <4 x i32> @vcvtauq(ptr %A) {
67 ; CHECK: vcvtauq
68 ; CHECK: vcvta.u32.f32 q{{[0-9]+}}, q{{[0-9]+}}
69   %tmp1 = load <4 x float>, ptr %A
70   %tmp2 = call <4 x i32> @llvm.arm.neon.vcvtau.v4i32.v4f32(<4 x float> %tmp1)
71   ret <4 x i32> %tmp2
74 define <2 x i32> @vcvtaud(ptr %A) {
75 ; CHECK: vcvtaud
76 ; CHECK: vcvta.u32.f32 d{{[0-9]+}}, d{{[0-9]+}}
77   %tmp1 = load <2 x float>, ptr %A
78   %tmp2 = call <2 x i32> @llvm.arm.neon.vcvtau.v2i32.v2f32(<2 x float> %tmp1)
79   ret <2 x i32> %tmp2
82 define <4 x i32> @vcvtnuq(ptr %A) {
83 ; CHECK: vcvtnuq
84 ; CHECK: vcvtn.u32.f32 q{{[0-9]+}}, q{{[0-9]+}}
85   %tmp1 = load <4 x float>, ptr %A
86   %tmp2 = call <4 x i32> @llvm.arm.neon.vcvtnu.v4i32.v4f32(<4 x float> %tmp1)
87   ret <4 x i32> %tmp2
90 define <2 x i32> @vcvtnud(ptr %A) {
91 ; CHECK: vcvtnud
92 ; CHECK: vcvtn.u32.f32 d{{[0-9]+}}, d{{[0-9]+}}
93   %tmp1 = load <2 x float>, ptr %A
94   %tmp2 = call <2 x i32> @llvm.arm.neon.vcvtnu.v2i32.v2f32(<2 x float> %tmp1)
95   ret <2 x i32> %tmp2
98 define <4 x i32> @vcvtpuq(ptr %A) {
99 ; CHECK: vcvtpuq
100 ; CHECK: vcvtp.u32.f32 q{{[0-9]+}}, q{{[0-9]+}}
101   %tmp1 = load <4 x float>, ptr %A
102   %tmp2 = call <4 x i32> @llvm.arm.neon.vcvtpu.v4i32.v4f32(<4 x float> %tmp1)
103   ret <4 x i32> %tmp2
106 define <2 x i32> @vcvtpud(ptr %A) {
107 ; CHECK: vcvtpud
108 ; CHECK: vcvtp.u32.f32 d{{[0-9]+}}, d{{[0-9]+}}
109   %tmp1 = load <2 x float>, ptr %A
110   %tmp2 = call <2 x i32> @llvm.arm.neon.vcvtpu.v2i32.v2f32(<2 x float> %tmp1)
111   ret <2 x i32> %tmp2
114 define <4 x i32> @vcvtmuq(ptr %A) {
115 ; CHECK: vcvtmuq
116 ; CHECK: vcvtm.u32.f32 q{{[0-9]+}}, q{{[0-9]+}}
117   %tmp1 = load <4 x float>, ptr %A
118   %tmp2 = call <4 x i32> @llvm.arm.neon.vcvtmu.v4i32.v4f32(<4 x float> %tmp1)
119   ret <4 x i32> %tmp2
122 define <2 x i32> @vcvtmud(ptr %A) {
123 ; CHECK: vcvtmud
124 ; CHECK: vcvtm.u32.f32 d{{[0-9]+}}, d{{[0-9]+}}
125   %tmp1 = load <2 x float>, ptr %A
126   %tmp2 = call <2 x i32> @llvm.arm.neon.vcvtmu.v2i32.v2f32(<2 x float> %tmp1)
127   ret <2 x i32> %tmp2
130 declare <4 x i32> @llvm.arm.neon.vcvtas.v4i32.v4f32(<4 x float>) nounwind readnone
131 declare <2 x i32> @llvm.arm.neon.vcvtas.v2i32.v2f32(<2 x float>) nounwind readnone
132 declare <4 x i32> @llvm.arm.neon.vcvtns.v4i32.v4f32(<4 x float>) nounwind readnone
133 declare <2 x i32> @llvm.arm.neon.vcvtns.v2i32.v2f32(<2 x float>) nounwind readnone
134 declare <4 x i32> @llvm.arm.neon.vcvtps.v4i32.v4f32(<4 x float>) nounwind readnone
135 declare <2 x i32> @llvm.arm.neon.vcvtps.v2i32.v2f32(<2 x float>) nounwind readnone
136 declare <4 x i32> @llvm.arm.neon.vcvtms.v4i32.v4f32(<4 x float>) nounwind readnone
137 declare <2 x i32> @llvm.arm.neon.vcvtms.v2i32.v2f32(<2 x float>) nounwind readnone
138 declare <4 x i32> @llvm.arm.neon.vcvtau.v4i32.v4f32(<4 x float>) nounwind readnone
139 declare <2 x i32> @llvm.arm.neon.vcvtau.v2i32.v2f32(<2 x float>) nounwind readnone
140 declare <4 x i32> @llvm.arm.neon.vcvtnu.v4i32.v4f32(<4 x float>) nounwind readnone
141 declare <2 x i32> @llvm.arm.neon.vcvtnu.v2i32.v2f32(<2 x float>) nounwind readnone
142 declare <4 x i32> @llvm.arm.neon.vcvtpu.v4i32.v4f32(<4 x float>) nounwind readnone
143 declare <2 x i32> @llvm.arm.neon.vcvtpu.v2i32.v2f32(<2 x float>) nounwind readnone
144 declare <4 x i32> @llvm.arm.neon.vcvtmu.v4i32.v4f32(<4 x float>) nounwind readnone
145 declare <2 x i32> @llvm.arm.neon.vcvtmu.v2i32.v2f32(<2 x float>) nounwind readnone