From 24f583c498a2fdb91a447eda754a29389b3a04d2 Mon Sep 17 00:00:00 2001 From: Lioncash Date: Sat, 13 Apr 2019 17:53:19 -0400 Subject: [PATCH] A64: Enable half-precision variants of floating-point FRINT* variants With all the backing machinery in place, we can remove the fallback check for half-precision. --- .../impl/floating_point_data_processing_one_register.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/frontend/A64/translate/impl/floating_point_data_processing_one_register.cpp b/src/frontend/A64/translate/impl/floating_point_data_processing_one_register.cpp index 66b6d377..a2556966 100644 --- a/src/frontend/A64/translate/impl/floating_point_data_processing_one_register.cpp +++ b/src/frontend/A64/translate/impl/floating_point_data_processing_one_register.cpp @@ -149,12 +149,12 @@ bool TranslatorVisitor::FCVT_float(Imm<2> type, Imm<2> opc, Vec Vn, Vec Vd) { static bool FloatingPointRoundToIntegral(TranslatorVisitor& v, Imm<2> type, Vec Vn, Vec Vd, FP::RoundingMode rounding_mode, bool exact) { const auto datasize = FPGetDataSize(type); - if (!datasize || *datasize == 16) { + if (!datasize) { return v.UnallocatedEncoding(); } - const IR::U32U64 operand = v.V_scalar(*datasize, Vn); - const IR::U32U64 result = v.ir.FPRoundInt(operand, rounding_mode, exact); + const IR::U16U32U64 operand = v.V_scalar(*datasize, Vn); + const IR::U16U32U64 result = v.ir.FPRoundInt(operand, rounding_mode, exact); v.V_scalar(*datasize, Vd, result); return true; }