mirror of https://gitee.com/openkylin/qemu.git
target/arm: Swap argument order for VSHL during decode
Rather than perform the argument swap during code generation, perform it during decode. This means it doesn't have to be special cased later, and we can share code with aarch64 code generation. Hopefully the decode comment addresses any confusion that might arise in between. Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20200513163245.17915-9-richard.henderson@linaro.org Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
271063206a
commit
e9eee5316f
|
@ -65,8 +65,21 @@ VCGT_U_3s 1111 001 1 0 . .. .... .... 0011 . . . 0 .... @3same
|
||||||
VCGE_S_3s 1111 001 0 0 . .. .... .... 0011 . . . 1 .... @3same
|
VCGE_S_3s 1111 001 0 0 . .. .... .... 0011 . . . 1 .... @3same
|
||||||
VCGE_U_3s 1111 001 1 0 . .. .... .... 0011 . . . 1 .... @3same
|
VCGE_U_3s 1111 001 1 0 . .. .... .... 0011 . . . 1 .... @3same
|
||||||
|
|
||||||
VSHL_S_3s 1111 001 0 0 . .. .... .... 0100 . . . 0 .... @3same
|
# The _rev suffix indicates that Vn and Vm are reversed. This is
|
||||||
VSHL_U_3s 1111 001 1 0 . .. .... .... 0100 . . . 0 .... @3same
|
# the case for shifts. In the Arm ARM these insns are documented
|
||||||
|
# with the Vm and Vn fields in their usual places, but in the
|
||||||
|
# assembly the operands are listed "backwards", ie in the order
|
||||||
|
# Dd, Dm, Dn where other insns use Dd, Dn, Dm. For QEMU we choose
|
||||||
|
# to consider Vm and Vn as being in different fields in the insn,
|
||||||
|
# which allows us to avoid special-casing shifts in the trans_
|
||||||
|
# function code. We would otherwise need to manually swap the operands
|
||||||
|
# over to call Neon helper functions that are shared with AArch64,
|
||||||
|
# which does not have this odd reversed-operand situation.
|
||||||
|
@3same_rev .... ... . . . size:2 .... .... .... . q:1 . . .... \
|
||||||
|
&3same vn=%vm_dp vm=%vn_dp vd=%vd_dp
|
||||||
|
|
||||||
|
VSHL_S_3s 1111 001 0 0 . .. .... .... 0100 . . . 0 .... @3same_rev
|
||||||
|
VSHL_U_3s 1111 001 1 0 . .. .... .... 0100 . . . 0 .... @3same_rev
|
||||||
|
|
||||||
VMAX_S_3s 1111 001 0 0 . .. .... .... 0110 . . . 0 .... @3same
|
VMAX_S_3s 1111 001 0 0 . .. .... .... 0110 . . . 0 .... @3same
|
||||||
VMAX_U_3s 1111 001 1 0 . .. .... .... 0110 . . . 0 .... @3same
|
VMAX_U_3s 1111 001 1 0 . .. .... .... 0110 . . . 0 .... @3same
|
||||||
|
|
|
@ -692,8 +692,7 @@ static bool trans_VMUL_p_3s(DisasContext *s, arg_3same *a)
|
||||||
uint32_t rn_ofs, uint32_t rm_ofs, \
|
uint32_t rn_ofs, uint32_t rm_ofs, \
|
||||||
uint32_t oprsz, uint32_t maxsz) \
|
uint32_t oprsz, uint32_t maxsz) \
|
||||||
{ \
|
{ \
|
||||||
/* Note the operation is vshl vd,vm,vn */ \
|
tcg_gen_gvec_3(rd_ofs, rn_ofs, rm_ofs, \
|
||||||
tcg_gen_gvec_3(rd_ofs, rm_ofs, rn_ofs, \
|
|
||||||
oprsz, maxsz, &OPARRAY[vece]); \
|
oprsz, maxsz, &OPARRAY[vece]); \
|
||||||
} \
|
} \
|
||||||
DO_3SAME(INSN, gen_##INSN##_3s)
|
DO_3SAME(INSN, gen_##INSN##_3s)
|
||||||
|
|
Loading…
Reference in New Issue