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