target/ppc: Move vexts[bhw]2[wd] to decodetree
Move the following instructions to decodetree: vextsb2w: Vector Extend Sign Byte To Word vextsh2w: Vector Extend Sign Halfword To Word vextsb2d: Vector Extend Sign Byte To Doubleword vextsh2d: Vector Extend Sign Halfword To Doubleword vextsw2d: Vector Extend Sign Word To Doubleword Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Lucas Coutinho <lucas.coutinho@eldorado.org.br> Signed-off-by: Matheus Ferst <matheus.ferst@eldorado.org.br> Message-Id: <20220225210936.1749575-8-matheus.ferst@eldorado.org.br> Signed-off-by: Cédric Le Goater <clg@kaod.org>
This commit is contained in:
parent
536f9876e2
commit
9bfe92135b
@ -242,11 +242,6 @@ DEF_HELPER_4(VINSBLX, void, env, avr, i64, tl)
|
||||
DEF_HELPER_4(VINSHLX, void, env, avr, i64, tl)
|
||||
DEF_HELPER_4(VINSWLX, void, env, avr, i64, tl)
|
||||
DEF_HELPER_4(VINSDLX, void, env, avr, i64, tl)
|
||||
DEF_HELPER_2(vextsb2w, void, avr, avr)
|
||||
DEF_HELPER_2(vextsh2w, void, avr, avr)
|
||||
DEF_HELPER_2(vextsb2d, void, avr, avr)
|
||||
DEF_HELPER_2(vextsh2d, void, avr, avr)
|
||||
DEF_HELPER_2(vextsw2d, void, avr, avr)
|
||||
DEF_HELPER_2(vnegw, void, avr, avr)
|
||||
DEF_HELPER_2(vnegd, void, avr, avr)
|
||||
DEF_HELPER_2(vupkhpx, void, avr, avr)
|
||||
|
@ -419,6 +419,14 @@ VINSWVRX 000100 ..... ..... ..... 00110001111 @VX
|
||||
VSLDBI 000100 ..... ..... ..... 00 ... 010110 @VN
|
||||
VSRDBI 000100 ..... ..... ..... 01 ... 010110 @VN
|
||||
|
||||
## Vector Integer Arithmetic Instructions
|
||||
|
||||
VEXTSB2W 000100 ..... 10000 ..... 11000000010 @VX_tb
|
||||
VEXTSH2W 000100 ..... 10001 ..... 11000000010 @VX_tb
|
||||
VEXTSB2D 000100 ..... 11000 ..... 11000000010 @VX_tb
|
||||
VEXTSH2D 000100 ..... 11001 ..... 11000000010 @VX_tb
|
||||
VEXTSW2D 000100 ..... 11010 ..... 11000000010 @VX_tb
|
||||
|
||||
## Vector Mask Manipulation Instructions
|
||||
|
||||
MTVSRBM 000100 ..... 10000 ..... 11001000010 @VX_tb
|
||||
|
@ -1630,21 +1630,6 @@ XXBLEND(W, 32)
|
||||
XXBLEND(D, 64)
|
||||
#undef XXBLEND
|
||||
|
||||
#define VEXT_SIGNED(name, element, cast) \
|
||||
void helper_##name(ppc_avr_t *r, ppc_avr_t *b) \
|
||||
{ \
|
||||
int i; \
|
||||
for (i = 0; i < ARRAY_SIZE(r->element); i++) { \
|
||||
r->element[i] = (cast)b->element[i]; \
|
||||
} \
|
||||
}
|
||||
VEXT_SIGNED(vextsb2w, s32, int8_t)
|
||||
VEXT_SIGNED(vextsb2d, s64, int8_t)
|
||||
VEXT_SIGNED(vextsh2w, s32, int16_t)
|
||||
VEXT_SIGNED(vextsh2d, s64, int16_t)
|
||||
VEXT_SIGNED(vextsw2d, s64, int32_t)
|
||||
#undef VEXT_SIGNED
|
||||
|
||||
#define VNEG(name, element) \
|
||||
void helper_##name(ppc_avr_t *r, ppc_avr_t *b) \
|
||||
{ \
|
||||
|
@ -1772,11 +1772,59 @@ GEN_VXFORM_TRANS(vclzw, 1, 30)
|
||||
GEN_VXFORM_TRANS(vclzd, 1, 31)
|
||||
GEN_VXFORM_NOA_2(vnegw, 1, 24, 6)
|
||||
GEN_VXFORM_NOA_2(vnegd, 1, 24, 7)
|
||||
GEN_VXFORM_NOA_2(vextsb2w, 1, 24, 16)
|
||||
GEN_VXFORM_NOA_2(vextsh2w, 1, 24, 17)
|
||||
GEN_VXFORM_NOA_2(vextsb2d, 1, 24, 24)
|
||||
GEN_VXFORM_NOA_2(vextsh2d, 1, 24, 25)
|
||||
GEN_VXFORM_NOA_2(vextsw2d, 1, 24, 26)
|
||||
|
||||
static void gen_vexts_i64(TCGv_i64 t, TCGv_i64 b, int64_t s)
|
||||
{
|
||||
tcg_gen_sextract_i64(t, b, 0, 64 - s);
|
||||
}
|
||||
|
||||
static void gen_vexts_i32(TCGv_i32 t, TCGv_i32 b, int32_t s)
|
||||
{
|
||||
tcg_gen_sextract_i32(t, b, 0, 32 - s);
|
||||
}
|
||||
|
||||
static void gen_vexts_vec(unsigned vece, TCGv_vec t, TCGv_vec b, int64_t s)
|
||||
{
|
||||
tcg_gen_shli_vec(vece, t, b, s);
|
||||
tcg_gen_sari_vec(vece, t, t, s);
|
||||
}
|
||||
|
||||
static bool do_vexts(DisasContext *ctx, arg_VX_tb *a, unsigned vece, int64_t s)
|
||||
{
|
||||
static const TCGOpcode vecop_list[] = {
|
||||
INDEX_op_shli_vec, INDEX_op_sari_vec, 0
|
||||
};
|
||||
|
||||
static const GVecGen2i op[2] = {
|
||||
{
|
||||
.fni4 = gen_vexts_i32,
|
||||
.fniv = gen_vexts_vec,
|
||||
.opt_opc = vecop_list,
|
||||
.vece = MO_32
|
||||
},
|
||||
{
|
||||
.fni8 = gen_vexts_i64,
|
||||
.fniv = gen_vexts_vec,
|
||||
.opt_opc = vecop_list,
|
||||
.vece = MO_64
|
||||
},
|
||||
};
|
||||
|
||||
REQUIRE_INSNS_FLAGS2(ctx, ISA300);
|
||||
REQUIRE_VECTOR(ctx);
|
||||
|
||||
tcg_gen_gvec_2i(avr_full_offset(a->vrt), avr_full_offset(a->vrb),
|
||||
16, 16, s, &op[vece - MO_32]);
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
TRANS(VEXTSB2W, do_vexts, MO_32, 24);
|
||||
TRANS(VEXTSH2W, do_vexts, MO_32, 16);
|
||||
TRANS(VEXTSB2D, do_vexts, MO_64, 56);
|
||||
TRANS(VEXTSH2D, do_vexts, MO_64, 48);
|
||||
TRANS(VEXTSW2D, do_vexts, MO_64, 32);
|
||||
|
||||
GEN_VXFORM_NOA_2(vctzb, 1, 24, 28)
|
||||
GEN_VXFORM_NOA_2(vctzh, 1, 24, 29)
|
||||
GEN_VXFORM_NOA_2(vctzw, 1, 24, 30)
|
||||
|
@ -216,11 +216,6 @@ GEN_VXFORM(vspltish, 6, 13),
|
||||
GEN_VXFORM(vspltisw, 6, 14),
|
||||
GEN_VXFORM_300_EO(vnegw, 0x01, 0x18, 0x06),
|
||||
GEN_VXFORM_300_EO(vnegd, 0x01, 0x18, 0x07),
|
||||
GEN_VXFORM_300_EO(vextsb2w, 0x01, 0x18, 0x10),
|
||||
GEN_VXFORM_300_EO(vextsh2w, 0x01, 0x18, 0x11),
|
||||
GEN_VXFORM_300_EO(vextsb2d, 0x01, 0x18, 0x18),
|
||||
GEN_VXFORM_300_EO(vextsh2d, 0x01, 0x18, 0x19),
|
||||
GEN_VXFORM_300_EO(vextsw2d, 0x01, 0x18, 0x1A),
|
||||
GEN_VXFORM_300_EO(vctzb, 0x01, 0x18, 0x1C),
|
||||
GEN_VXFORM_300_EO(vctzh, 0x01, 0x18, 0x1D),
|
||||
GEN_VXFORM_300_EO(vctzw, 0x01, 0x18, 0x1E),
|
||||
|
Loading…
Reference in New Issue
Block a user