From 9b42d0148084fbe7d5bea24813f8c30b5ed9d8b9 Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Tue, 15 May 2018 22:08:01 -0400 Subject: [PATCH] target/arm: Implement FCVT (scalar, fixed-point) for fp16 Backports commit 2752728016bef06e7c9cfb961019272859beeca4 from qemu --- qemu/target/arm/translate-a64.c | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/qemu/target/arm/translate-a64.c b/qemu/target/arm/translate-a64.c index f48fa1fe..a83c78d4 100644 --- a/qemu/target/arm/translate-a64.c +++ b/qemu/target/arm/translate-a64.c @@ -5798,8 +5798,21 @@ static void disas_fp_fixed_conv(DisasContext *s, uint32_t insn) bool sf = extract32(insn, 31, 1); bool itof; - if (sbit || (type > 1) - || (!sf && scale < 32)) { + if (sbit || (!sf && scale < 32)) { + unallocated_encoding(s); + return; + } + + switch (type) { + case 0: /* float32 */ + case 1: /* float64 */ + break; + case 3: /* float16 */ + if (arm_dc_feature(s, ARM_FEATURE_V8_FP16)) { + break; + } + /* fallthru */ + default: unallocated_encoding(s); return; }