mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-25 19:21:01 +00:00
target/mips: Add emulation of MMI instruction PCPYUD
Add emulation of MMI instruction PCPYUD. The emulation is implemented using TCG front end operations directly to achieve better performance. Backports commit fd487f83ea92d790559813c5a0a719c30ca9ecde from qemu
This commit is contained in:
parent
c5e3fc601c
commit
4b272cbe93
|
@ -24590,6 +24590,46 @@ static void gen_mmi_pcpyld(DisasContext *ctx)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* PCPYUD rd, rs, rt
|
||||||
|
*
|
||||||
|
* Parallel Copy Upper Doubleword
|
||||||
|
*
|
||||||
|
* 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0
|
||||||
|
* +-----------+---------+---------+---------+---------+-----------+
|
||||||
|
* | MMI | rs | rt | rd | PCPYUD | MMI3 |
|
||||||
|
* +-----------+---------+---------+---------+---------+-----------+
|
||||||
|
*/
|
||||||
|
static void gen_mmi_pcpyud(DisasContext *ctx)
|
||||||
|
{
|
||||||
|
TCGContext *tcg_ctx = ctx->uc->tcg_ctx;
|
||||||
|
uint32_t rs, rt, rd;
|
||||||
|
uint32_t opcode;
|
||||||
|
|
||||||
|
opcode = ctx->opcode;
|
||||||
|
|
||||||
|
rs = extract32(opcode, 21, 5);
|
||||||
|
rt = extract32(opcode, 16, 5);
|
||||||
|
rd = extract32(opcode, 11, 5);
|
||||||
|
|
||||||
|
if (rd == 0) {
|
||||||
|
/* nop */
|
||||||
|
} else {
|
||||||
|
if (rs == 0) {
|
||||||
|
tcg_gen_movi_i64(tcg_ctx, tcg_ctx->cpu_gpr[rd], 0);
|
||||||
|
} else {
|
||||||
|
tcg_gen_mov_i64(tcg_ctx, tcg_ctx->cpu_gpr[rd], tcg_ctx->cpu_mmr[rs]);
|
||||||
|
}
|
||||||
|
if (rt == 0) {
|
||||||
|
tcg_gen_movi_i64(tcg_ctx, tcg_ctx->cpu_mmr[rd], 0);
|
||||||
|
} else {
|
||||||
|
if (rd != rt) {
|
||||||
|
tcg_gen_mov_i64(tcg_ctx, tcg_ctx->cpu_mmr[rd], tcg_ctx->cpu_mmr[rt]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
@ -27654,7 +27694,6 @@ static void decode_mmi3(CPUMIPSState *env, DisasContext *ctx)
|
||||||
case MMI_OPC_3_PINTEH: /* TODO: MMI_OPC_3_PINTEH */
|
case MMI_OPC_3_PINTEH: /* TODO: MMI_OPC_3_PINTEH */
|
||||||
case MMI_OPC_3_PMULTUW: /* TODO: MMI_OPC_3_PMULTUW */
|
case MMI_OPC_3_PMULTUW: /* TODO: MMI_OPC_3_PMULTUW */
|
||||||
case MMI_OPC_3_PDIVUW: /* TODO: MMI_OPC_3_PDIVUW */
|
case MMI_OPC_3_PDIVUW: /* TODO: MMI_OPC_3_PDIVUW */
|
||||||
case MMI_OPC_3_PCPYUD: /* TODO: MMI_OPC_3_PCPYUD */
|
|
||||||
case MMI_OPC_3_POR: /* TODO: MMI_OPC_3_POR */
|
case MMI_OPC_3_POR: /* TODO: MMI_OPC_3_POR */
|
||||||
case MMI_OPC_3_PNOR: /* TODO: MMI_OPC_3_PNOR */
|
case MMI_OPC_3_PNOR: /* TODO: MMI_OPC_3_PNOR */
|
||||||
case MMI_OPC_3_PEXCH: /* TODO: MMI_OPC_3_PEXCH */
|
case MMI_OPC_3_PEXCH: /* TODO: MMI_OPC_3_PEXCH */
|
||||||
|
@ -27664,6 +27703,9 @@ static void decode_mmi3(CPUMIPSState *env, DisasContext *ctx)
|
||||||
case MMI_OPC_3_PCPYH:
|
case MMI_OPC_3_PCPYH:
|
||||||
gen_mmi_pcpyh(ctx);
|
gen_mmi_pcpyh(ctx);
|
||||||
break;
|
break;
|
||||||
|
case MMI_OPC_3_PCPYUD:
|
||||||
|
gen_mmi_pcpyud(ctx);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
MIPS_INVAL("TX79 MMI class MMI3");
|
MIPS_INVAL("TX79 MMI class MMI3");
|
||||||
generate_exception_end(ctx, EXCP_RI);
|
generate_exception_end(ctx, EXCP_RI);
|
||||||
|
|
Loading…
Reference in a new issue