From: Chad Rosier Date: Tue, 10 Dec 2013 21:34:20 +0000 (+0000) Subject: [AArch64] Overload NEON signed/unsigned floating-point convert to fixed-point X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=f33217a0633428266ecae1c4da8f278ee7d75be8;p=clang [AArch64] Overload NEON signed/unsigned floating-point convert to fixed-point and fixed-point convert to floating-point LLVM AArch64 intrinsics. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@196967 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGBuiltin.cpp b/lib/CodeGen/CGBuiltin.cpp index 97fe987d53..c54112192f 100644 --- a/lib/CodeGen/CGBuiltin.cpp +++ b/lib/CodeGen/CGBuiltin.cpp @@ -2532,32 +2532,24 @@ static Value *EmitAArch64ScalarBuiltinExpr(CodeGenFunction &CGF, s = "vsqrshrun"; IntTypes = VectorRet; break; // Scalar Signed Fixed-point Convert To Floating-Point (Immediate) case AArch64::BI__builtin_neon_vcvts_n_f32_s32: - Int = Intrinsic::aarch64_neon_vcvtf32_n_s32; - s = "vcvtf"; break; case AArch64::BI__builtin_neon_vcvtd_n_f64_s64: - Int = Intrinsic::aarch64_neon_vcvtf64_n_s64; - s = "vcvtf"; break; + Int = Intrinsic::aarch64_neon_vcvtfxs2fp_n; + s = "vcvtf"; IntTypes = ScalarRet | VectorGetArg0; break; // Scalar Unsigned Fixed-point Convert To Floating-Point (Immediate) case AArch64::BI__builtin_neon_vcvts_n_f32_u32: - Int = Intrinsic::aarch64_neon_vcvtf32_n_u32; - s = "vcvtf"; break; case AArch64::BI__builtin_neon_vcvtd_n_f64_u64: - Int = Intrinsic::aarch64_neon_vcvtf64_n_u64; - s = "vcvtf"; break; + Int = Intrinsic::aarch64_neon_vcvtfxu2fp_n; + s = "vcvtf"; IntTypes = ScalarRet | VectorGetArg0; break; // Scalar Floating-point Convert To Signed Fixed-point (Immediate) case AArch64::BI__builtin_neon_vcvts_n_s32_f32: - Int = Intrinsic::aarch64_neon_vcvts_n_s32_f32; - s = "fcvtzs"; break; case AArch64::BI__builtin_neon_vcvtd_n_s64_f64: - Int = Intrinsic::aarch64_neon_vcvtd_n_s64_f64; - s = "fcvtzs"; break; + Int = Intrinsic::aarch64_neon_vcvtfp2fxs_n; + s = "fcvtzs"; IntTypes = VectorRet | VectorGetArg0; break; // Scalar Floating-point Convert To Unsigned Fixed-point (Immediate) case AArch64::BI__builtin_neon_vcvts_n_u32_f32: - Int = Intrinsic::aarch64_neon_vcvts_n_u32_f32; - s = "fcvtzu"; break; case AArch64::BI__builtin_neon_vcvtd_n_u64_f64: - Int = Intrinsic::aarch64_neon_vcvtd_n_u64_f64; - s = "fcvtzu"; break; + Int = Intrinsic::aarch64_neon_vcvtfp2fxu_n; + s = "fcvtzu"; IntTypes = VectorRet | VectorGetArg0; break; case AArch64::BI__builtin_neon_vmull_p64: Int = Intrinsic::aarch64_neon_vmull_p64; s = "vmull"; break;