[InstCombine] Signed saturation patterns
[llvm-core.git] / test / CodeGen / AArch64 / arm64-vcvt_n.ll
blobc2380a390577bf3a285df6ecde3a82ad939423c2
1 ; RUN: llc < %s -mtriple=arm64-eabi -aarch64-neon-syntax=apple | FileCheck %s
3 define <2 x float> @cvtf32fxpu(<2 x i32> %a) nounwind readnone ssp {
4 ; CHECK-LABEL: cvtf32fxpu:
5 ; CHECK: ucvtf.2s       v0, v0, #9
6 ; CHECK: ret
7   %vcvt_n1 = tail call <2 x float> @llvm.aarch64.neon.vcvtfxu2fp.v2f32.v2i32(<2 x i32> %a, i32 9)
8   ret <2 x float> %vcvt_n1
11 define <2 x float> @cvtf32fxps(<2 x i32> %a) nounwind readnone ssp {
12 ; CHECK-LABEL: cvtf32fxps:
13 ; CHECK: scvtf.2s       v0, v0, #12
14 ; CHECK: ret
15   %vcvt_n1 = tail call <2 x float> @llvm.aarch64.neon.vcvtfxs2fp.v2f32.v2i32(<2 x i32> %a, i32 12)
16   ret <2 x float> %vcvt_n1
19 define <4 x float> @cvtqf32fxpu(<4 x i32> %a) nounwind readnone ssp {
20 ; CHECK-LABEL: cvtqf32fxpu:
21 ; CHECK: ucvtf.4s       v0, v0, #18
22 ; CHECK: ret
23   %vcvt_n1 = tail call <4 x float> @llvm.aarch64.neon.vcvtfxu2fp.v4f32.v4i32(<4 x i32> %a, i32 18)
24   ret <4 x float> %vcvt_n1
27 define <4 x float> @cvtqf32fxps(<4 x i32> %a) nounwind readnone ssp {
28 ; CHECK-LABEL: cvtqf32fxps:
29 ; CHECK: scvtf.4s       v0, v0, #30
30 ; CHECK: ret
31   %vcvt_n1 = tail call <4 x float> @llvm.aarch64.neon.vcvtfxs2fp.v4f32.v4i32(<4 x i32> %a, i32 30)
32   ret <4 x float> %vcvt_n1
34 define <2 x double> @f1(<2 x i64> %a) nounwind readnone ssp {
35   %vcvt_n1 = tail call <2 x double> @llvm.aarch64.neon.vcvtfxu2fp.v2f64.v2i64(<2 x i64> %a, i32 12)
36   ret <2 x double> %vcvt_n1
39 define <2 x double> @f2(<2 x i64> %a) nounwind readnone ssp {
40   %vcvt_n1 = tail call <2 x double> @llvm.aarch64.neon.vcvtfxs2fp.v2f64.v2i64(<2 x i64> %a, i32 9)
41   ret <2 x double> %vcvt_n1
44 declare <4 x float> @llvm.aarch64.neon.vcvtfxu2fp.v4f32.v4i32(<4 x i32>, i32) nounwind readnone
45 declare <4 x float> @llvm.aarch64.neon.vcvtfxs2fp.v4f32.v4i32(<4 x i32>, i32) nounwind readnone
46 declare <2 x float> @llvm.aarch64.neon.vcvtfxu2fp.v2f32.v2i32(<2 x i32>, i32) nounwind readnone
47 declare <2 x float> @llvm.aarch64.neon.vcvtfxs2fp.v2f32.v2i32(<2 x i32>, i32) nounwind readnone
48 declare <2 x double> @llvm.aarch64.neon.vcvtfxu2fp.v2f64.v2i64(<2 x i64>, i32) nounwind readnone
49 declare <2 x double> @llvm.aarch64.neon.vcvtfxs2fp.v2f64.v2i64(<2 x i64>, i32) nounwind readnone