target-arm: Fix mixup in decoding of saturating add and sub
The thumb2 decoder contained a mixup between the bit controlling doubling and the bit controlling if the operation was an add or a sub. Signed-off-by: Johan Bengtsson <teofrastius@gmail.com> Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Nathan Froyd <froydnj@codesourcery.com>
This commit is contained in:
parent
2af9ab7737
commit
4809c612bc
@ -7713,9 +7713,9 @@ static int disas_thumb2_insn(CPUState *env, DisasContext *s, uint16_t insn_hw1)
|
||||
/* Saturating add/subtract. */
|
||||
tmp = load_reg(s, rn);
|
||||
tmp2 = load_reg(s, rm);
|
||||
if (op & 2)
|
||||
gen_helper_double_saturate(tmp, tmp);
|
||||
if (op & 1)
|
||||
gen_helper_double_saturate(tmp, tmp);
|
||||
if (op & 2)
|
||||
gen_helper_sub_saturate(tmp, tmp2, tmp);
|
||||
else
|
||||
gen_helper_add_saturate(tmp, tmp, tmp2);
|
||||
|
Loading…
x
Reference in New Issue
Block a user