target-mips: fix translation of MT instructions

The translation of dmt/emt/dvpe/evpe was doing the moral equivalent of:

  int x;
  ...		/* no initialization of x */
  x = f (x);

which confused later bits of TCG rather badly, leading to crashes.

Fix the helpers to only return results (those instructions have no
inputs), and fix the translation code accordingly.

Signed-off-by: Nathan Froyd <froydnj@codesourcery.com>
Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
This commit is contained in:
Nathan Froyd 2010-10-29 07:48:46 -07:00 committed by Aurelien Jarno
parent cbb608a5c8
commit 9ed5726c04
3 changed files with 16 additions and 28 deletions

View File

@ -154,10 +154,10 @@ DEF_HELPER_2(mttlo, void, tl, i32)
DEF_HELPER_2(mtthi, void, tl, i32) DEF_HELPER_2(mtthi, void, tl, i32)
DEF_HELPER_2(mttacx, void, tl, i32) DEF_HELPER_2(mttacx, void, tl, i32)
DEF_HELPER_1(mttdsp, void, tl) DEF_HELPER_1(mttdsp, void, tl)
DEF_HELPER_1(dmt, tl, tl) DEF_HELPER_0(dmt, tl)
DEF_HELPER_1(emt, tl, tl) DEF_HELPER_0(emt, tl)
DEF_HELPER_1(dvpe, tl, tl) DEF_HELPER_0(dvpe, tl)
DEF_HELPER_1(evpe, tl, tl) DEF_HELPER_0(evpe, tl)
#endif /* !CONFIG_USER_ONLY */ #endif /* !CONFIG_USER_ONLY */
/* microMIPS functions */ /* microMIPS functions */

View File

@ -1554,40 +1554,28 @@ void helper_mttdsp(target_ulong arg1)
} }
/* MIPS MT functions */ /* MIPS MT functions */
target_ulong helper_dmt(target_ulong arg1) target_ulong helper_dmt(void)
{ {
// TODO // TODO
arg1 = 0; return 0;
// rt = arg1
return arg1;
} }
target_ulong helper_emt(target_ulong arg1) target_ulong helper_emt(void)
{ {
// TODO // TODO
arg1 = 0; return 0;
// rt = arg1
return arg1;
} }
target_ulong helper_dvpe(target_ulong arg1) target_ulong helper_dvpe(void)
{ {
// TODO // TODO
arg1 = 0; return 0;
// rt = arg1
return arg1;
} }
target_ulong helper_evpe(target_ulong arg1) target_ulong helper_evpe(void)
{ {
// TODO // TODO
arg1 = 0; return 0;
// rt = arg1
return arg1;
} }
#endif /* !CONFIG_USER_ONLY */ #endif /* !CONFIG_USER_ONLY */

View File

@ -12033,22 +12033,22 @@ static void decode_opc (CPUState *env, DisasContext *ctx, int *is_branch)
switch (op2) { switch (op2) {
case OPC_DMT: case OPC_DMT:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_helper_dmt(t0, t0); gen_helper_dmt(t0);
gen_store_gpr(t0, rt); gen_store_gpr(t0, rt);
break; break;
case OPC_EMT: case OPC_EMT:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_helper_emt(t0, t0); gen_helper_emt(t0);
gen_store_gpr(t0, rt); gen_store_gpr(t0, rt);
break; break;
case OPC_DVPE: case OPC_DVPE:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_helper_dvpe(t0, t0); gen_helper_dvpe(t0);
gen_store_gpr(t0, rt); gen_store_gpr(t0, rt);
break; break;
case OPC_EVPE: case OPC_EVPE:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_helper_evpe(t0, t0); gen_helper_evpe(t0);
gen_store_gpr(t0, rt); gen_store_gpr(t0, rt);
break; break;
case OPC_DI: case OPC_DI: