1 // RUN: %clang_cc1 -triple arm64-none-linux-gnu -target-feature +neon \ 2 // RUN: -emit-llvm -o - %s | opt -S -mem2reg | FileCheck %s 3 4 // Test new aarch64 intrinsics and types 5 6 #include <arm_neon.h> 7 8 // CHECK-LABEL: define float @test_vcvtxd_f32_f64(double %a) #0 { 9 // CHECK: [[VCVTXD_F32_F64_I:%.*]] = call float @llvm.aarch64.sisd.fcvtxn(double %a) #2 10 // CHECK: ret float [[VCVTXD_F32_F64_I]] 11 float32_t test_vcvtxd_f32_f64(float64_t a) { 12 return (float32_t)vcvtxd_f32_f64(a); 13 } 14 15 // CHECK-LABEL: define i32 @test_vcvtas_s32_f32(float %a) #0 { 16 // CHECK: [[VCVTAS_S32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtas.i32.f32(float %a) #2 17 // CHECK: ret i32 [[VCVTAS_S32_F32_I]] 18 int32_t test_vcvtas_s32_f32(float32_t a) { 19 return (int32_t)vcvtas_s32_f32(a); 20 } 21 22 // CHECK-LABEL: define i64 @test_test_vcvtad_s64_f64(double %a) #0 { 23 // CHECK: [[VCVTAD_S64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtas.i64.f64(double %a) #2 24 // CHECK: ret i64 [[VCVTAD_S64_F64_I]] 25 int64_t test_test_vcvtad_s64_f64(float64_t a) { 26 return (int64_t)vcvtad_s64_f64(a); 27 } 28 29 // CHECK-LABEL: define i32 @test_vcvtas_u32_f32(float %a) #0 { 30 // CHECK: [[VCVTAS_U32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtau.i32.f32(float %a) #2 31 // CHECK: ret i32 [[VCVTAS_U32_F32_I]] 32 uint32_t test_vcvtas_u32_f32(float32_t a) { 33 return (uint32_t)vcvtas_u32_f32(a); 34 } 35 36 // CHECK-LABEL: define i64 @test_vcvtad_u64_f64(double %a) #0 { 37 // CHECK: [[VCVTAD_U64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtau.i64.f64(double %a) #2 38 // CHECK: ret i64 [[VCVTAD_U64_F64_I]] 39 uint64_t test_vcvtad_u64_f64(float64_t a) { 40 return (uint64_t)vcvtad_u64_f64(a); 41 } 42 43 // CHECK-LABEL: define i32 @test_vcvtms_s32_f32(float %a) #0 { 44 // CHECK: [[VCVTMS_S32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtms.i32.f32(float %a) #2 45 // CHECK: ret i32 [[VCVTMS_S32_F32_I]] 46 int32_t test_vcvtms_s32_f32(float32_t a) { 47 return (int32_t)vcvtms_s32_f32(a); 48 } 49 50 // CHECK-LABEL: define i64 @test_vcvtmd_s64_f64(double %a) #0 { 51 // CHECK: [[VCVTMD_S64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtms.i64.f64(double %a) #2 52 // CHECK: ret i64 [[VCVTMD_S64_F64_I]] 53 int64_t test_vcvtmd_s64_f64(float64_t a) { 54 return (int64_t)vcvtmd_s64_f64(a); 55 } 56 57 // CHECK-LABEL: define i32 @test_vcvtms_u32_f32(float %a) #0 { 58 // CHECK: [[VCVTMS_U32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtmu.i32.f32(float %a) #2 59 // CHECK: ret i32 [[VCVTMS_U32_F32_I]] 60 uint32_t test_vcvtms_u32_f32(float32_t a) { 61 return (uint32_t)vcvtms_u32_f32(a); 62 } 63 64 // CHECK-LABEL: define i64 @test_vcvtmd_u64_f64(double %a) #0 { 65 // CHECK: [[VCVTMD_U64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtmu.i64.f64(double %a) #2 66 // CHECK: ret i64 [[VCVTMD_U64_F64_I]] 67 uint64_t test_vcvtmd_u64_f64(float64_t a) { 68 return (uint64_t)vcvtmd_u64_f64(a); 69 } 70 71 // CHECK-LABEL: define i32 @test_vcvtns_s32_f32(float %a) #0 { 72 // CHECK: [[VCVTNS_S32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtns.i32.f32(float %a) #2 73 // CHECK: ret i32 [[VCVTNS_S32_F32_I]] 74 int32_t test_vcvtns_s32_f32(float32_t a) { 75 return (int32_t)vcvtns_s32_f32(a); 76 } 77 78 // CHECK-LABEL: define i64 @test_vcvtnd_s64_f64(double %a) #0 { 79 // CHECK: [[VCVTND_S64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtns.i64.f64(double %a) #2 80 // CHECK: ret i64 [[VCVTND_S64_F64_I]] 81 int64_t test_vcvtnd_s64_f64(float64_t a) { 82 return (int64_t)vcvtnd_s64_f64(a); 83 } 84 85 // CHECK-LABEL: define i32 @test_vcvtns_u32_f32(float %a) #0 { 86 // CHECK: [[VCVTNS_U32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtnu.i32.f32(float %a) #2 87 // CHECK: ret i32 [[VCVTNS_U32_F32_I]] 88 uint32_t test_vcvtns_u32_f32(float32_t a) { 89 return (uint32_t)vcvtns_u32_f32(a); 90 } 91 92 // CHECK-LABEL: define i64 @test_vcvtnd_u64_f64(double %a) #0 { 93 // CHECK: [[VCVTND_U64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtnu.i64.f64(double %a) #2 94 // CHECK: ret i64 [[VCVTND_U64_F64_I]] 95 uint64_t test_vcvtnd_u64_f64(float64_t a) { 96 return (uint64_t)vcvtnd_u64_f64(a); 97 } 98 99 // CHECK-LABEL: define i32 @test_vcvtps_s32_f32(float %a) #0 { 100 // CHECK: [[VCVTPS_S32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtps.i32.f32(float %a) #2 101 // CHECK: ret i32 [[VCVTPS_S32_F32_I]] 102 int32_t test_vcvtps_s32_f32(float32_t a) { 103 return (int32_t)vcvtps_s32_f32(a); 104 } 105 106 // CHECK-LABEL: define i64 @test_vcvtpd_s64_f64(double %a) #0 { 107 // CHECK: [[VCVTPD_S64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtps.i64.f64(double %a) #2 108 // CHECK: ret i64 [[VCVTPD_S64_F64_I]] 109 int64_t test_vcvtpd_s64_f64(float64_t a) { 110 return (int64_t)vcvtpd_s64_f64(a); 111 } 112 113 // CHECK-LABEL: define i32 @test_vcvtps_u32_f32(float %a) #0 { 114 // CHECK: [[VCVTPS_U32_F32_I:%.*]] = call i32 @llvm.aarch64.neon.fcvtpu.i32.f32(float %a) #2 115 // CHECK: ret i32 [[VCVTPS_U32_F32_I]] 116 uint32_t test_vcvtps_u32_f32(float32_t a) { 117 return (uint32_t)vcvtps_u32_f32(a); 118 } 119 120 // CHECK-LABEL: define i64 @test_vcvtpd_u64_f64(double %a) #0 { 121 // CHECK: [[VCVTPD_U64_F64_I:%.*]] = call i64 @llvm.aarch64.neon.fcvtpu.i64.f64(double %a) #2 122 // CHECK: ret i64 [[VCVTPD_U64_F64_I]] 123 uint64_t test_vcvtpd_u64_f64(float64_t a) { 124 return (uint64_t)vcvtpd_u64_f64(a); 125 } 126 127 // CHECK-LABEL: define i32 @test_vcvts_s32_f32(float %a) #0 { 128 // CHECK: [[TMP0:%.*]] = fptosi float %a to i32 129 // CHECK: ret i32 [[TMP0]] 130 int32_t test_vcvts_s32_f32(float32_t a) { 131 return (int32_t)vcvts_s32_f32(a); 132 } 133 134 // CHECK-LABEL: define i64 @test_vcvtd_s64_f64(double %a) #0 { 135 // CHECK: [[TMP0:%.*]] = fptosi double %a to i64 136 // CHECK: ret i64 [[TMP0]] 137 int64_t test_vcvtd_s64_f64(float64_t a) { 138 return (int64_t)vcvtd_s64_f64(a); 139 } 140 141 // CHECK-LABEL: define i32 @test_vcvts_u32_f32(float %a) #0 { 142 // CHECK: [[TMP0:%.*]] = fptoui float %a to i32 143 // CHECK: ret i32 [[TMP0]] 144 uint32_t test_vcvts_u32_f32(float32_t a) { 145 return (uint32_t)vcvts_u32_f32(a); 146 } 147 148 // CHECK-LABEL: define i64 @test_vcvtd_u64_f64(double %a) #0 { 149 // CHECK: [[TMP0:%.*]] = fptoui double %a to i64 150 // CHECK: ret i64 [[TMP0]] 151 uint64_t test_vcvtd_u64_f64(float64_t a) { 152 return (uint64_t)vcvtd_u64_f64(a); 153 } 154