Nikunj A Dadhania <nik...@linux.vnet.ibm.com> writes: > stxsd: Store VSX Scalar Dword > stxssp: Store VSX Scalar SP > > Moreover, DQ-Form/DS-FORM instructions shares the same primary > opcode(0x3D), bits 29:31 are used to decode the instruction. Us e a > common routine to decode primary opcode(0x3D) - ds-form/dq-form > instructions.
Realised that the below logic wast correct, should be something like this: static void gen_dform3D(DisasContext *ctx) { if ((ctx->opcode & 3) == 1) { /* DQ-FORM */ switch (ctx->opcode & 0x7) { case 1: /* lxv */ if (ctx->insns_flags2 & PPC2_ISA300) { return gen_lxv(ctx); } break; case 5: /* stxv */ if (ctx->insns_flags2 & PPC2_ISA300) { return gen_stxv(ctx); } break; } } else { /* DS-FORM */ switch (ctx->opcode & 0x3) { case 0: /* lfdp */ if (ctx->insns_flags2 & PPC2_ISA205) { return gen_stfdp(ctx); } break; case 2: /* lxsd */ if (ctx->insns_flags2 & PPC2_ISA300) { return gen_stxsd(ctx); } break; case 3: /* lxssp */ if (ctx->insns_flags2 & PPC2_ISA300) { return gen_stxssp(ctx); } break; } } return gen_invalid(ctx); } Will correct it in next revision. > > Signed-off-by: Nikunj A Dadhania <nik...@linux.vnet.ibm.com> > --- > target-ppc/translate.c | 25 +++++++++++++++++++++++++ > target-ppc/translate/fp-ops.inc.c | 1 - > target-ppc/translate/vsx-impl.inc.c | 21 +++++++++++++++++++++ > 3 files changed, 46 insertions(+), 1 deletion(-) > > diff --git a/target-ppc/translate.c b/target-ppc/translate.c > index f280851..bce607b 100644 > --- a/target-ppc/translate.c > +++ b/target-ppc/translate.c > @@ -6076,6 +6076,29 @@ static void gen_dform39(DisasContext *ctx) > return gen_invalid(ctx); > } > > +/* handles stfdp, stxsd, stxssp */ > +static void gen_dform3D(DisasContext *ctx) > +{ > + switch (ctx->opcode & 0x7) { > + case 0: /* lfdp */ > + if (ctx->insns_flags2 & PPC2_ISA205) { > + return gen_stfdp(ctx); > + } > + break; > + case 2: /* lxsd */ > + if (ctx->insns_flags2 & PPC2_ISA300) { > + return gen_stxsd(ctx); > + } > + break; > + case 3: /* lxssp */ > + if (ctx->insns_flags2 & PPC2_ISA300) { > + return gen_stxssp(ctx); > + } > + break; > + } > + return gen_invalid(ctx); > +} > +