diff options
author | Peter Maydell <peter.maydell@linaro.org> | 2019-05-31 15:08:22 +0100 |
---|---|---|
committer | Peter Maydell <peter.maydell@linaro.org> | 2019-06-04 14:58:29 +0100 |
commit | b7b1dbf8874bcc1559f7860b86e73c948c2c883c (patch) | |
tree | c1d3a1e87cdba82cae682b646e46ccf39779ada7 /target/arm/translate.c | |
parent | f68f3b37645f1d994d9ec400ac1183911dabb207 (diff) |
target/arm: Convert VFP VMLS to decodetree
Convert the VFP VMLS instruction to decodetree.
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Diffstat (limited to 'target/arm/translate.c')
-rw-r--r-- | target/arm/translate.c | 8 |
1 files changed, 1 insertions, 7 deletions
diff --git a/target/arm/translate.c b/target/arm/translate.c index 6f0daddbbc..ae05cb767b 100644 --- a/target/arm/translate.c +++ b/target/arm/translate.c @@ -3124,7 +3124,7 @@ static int disas_vfp_insn(DisasContext *s, uint32_t insn) rn = VFP_SREG_N(insn); switch (op) { - case 0: + case 0 ... 1: /* Already handled by decodetree */ return 1; default: @@ -3310,12 +3310,6 @@ static int disas_vfp_insn(DisasContext *s, uint32_t insn) for (;;) { /* Perform the calculation. */ switch (op) { - case 1: /* VMLS: fd + -(fn * fm) */ - gen_vfp_mul(dp); - gen_vfp_F1_neg(dp); - gen_mov_F0_vreg(dp, rd); - gen_vfp_add(dp); - break; case 2: /* VNMLS: -fd + (fn * fm) */ /* Note that it isn't valid to replace (-A + B) with (B - A) * or similar plausible looking simplifications |