提交 1a3fd9c3 编写于 作者: T ths

Remove remaining uses of T0 in the MIPS target.


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4788 c046a42c-6fe2-441c-8c8c-71466251a162
上级 e1bf387e
...@@ -140,9 +140,6 @@ struct CPUMIPSState { ...@@ -140,9 +140,6 @@ struct CPUMIPSState {
target_ulong gpr[MIPS_SHADOW_SET_MAX][32]; target_ulong gpr[MIPS_SHADOW_SET_MAX][32];
/* Special registers */ /* Special registers */
target_ulong PC[MIPS_TC_MAX]; target_ulong PC[MIPS_TC_MAX];
#if TARGET_LONG_BITS > HOST_LONG_BITS
target_ulong t0;
#endif
/* temporary hack for FP globals */ /* temporary hack for FP globals */
#ifndef USE_HOST_FLOAT_REGS #ifndef USE_HOST_FLOAT_REGS
fpr_t ft0; fpr_t ft0;
......
...@@ -10,12 +10,6 @@ ...@@ -10,12 +10,6 @@
register struct CPUMIPSState *env asm(AREG0); register struct CPUMIPSState *env asm(AREG0);
#if TARGET_LONG_BITS > HOST_LONG_BITS
#define T0 (env->t0)
#else
register target_ulong T0 asm(AREG1);
#endif
#if defined (USE_HOST_FLOAT_REGS) #if defined (USE_HOST_FLOAT_REGS)
#error "implement me." #error "implement me."
#else #else
......
...@@ -43,40 +43,40 @@ DEF_HELPER(target_ulong, do_msachiu, (target_ulong t0, target_ulong t1)) ...@@ -43,40 +43,40 @@ DEF_HELPER(target_ulong, do_msachiu, (target_ulong t0, target_ulong t1))
/* CP0 helpers */ /* CP0 helpers */
#ifndef CONFIG_USER_ONLY #ifndef CONFIG_USER_ONLY
DEF_HELPER(target_ulong, do_mfc0_mvpcontrol, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_mvpcontrol, (void))
DEF_HELPER(target_ulong, do_mfc0_mvpconf0, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_mvpconf0, (void))
DEF_HELPER(target_ulong, do_mfc0_mvpconf1, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_mvpconf1, (void))
DEF_HELPER(target_ulong, do_mfc0_random, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_random, (void))
DEF_HELPER(target_ulong, do_mfc0_tcstatus, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_tcstatus, (void))
DEF_HELPER(target_ulong, do_mftc0_tcstatus, (target_ulong t0)) DEF_HELPER(target_ulong, do_mftc0_tcstatus, (void))
DEF_HELPER(target_ulong, do_mfc0_tcbind, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_tcbind, (void))
DEF_HELPER(target_ulong, do_mftc0_tcbind, (target_ulong t0)) DEF_HELPER(target_ulong, do_mftc0_tcbind, (void))
DEF_HELPER(target_ulong, do_mfc0_tcrestart, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_tcrestart, (void))
DEF_HELPER(target_ulong, do_mftc0_tcrestart, (target_ulong t0)) DEF_HELPER(target_ulong, do_mftc0_tcrestart, (void))
DEF_HELPER(target_ulong, do_mfc0_tchalt, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_tchalt, (void))
DEF_HELPER(target_ulong, do_mftc0_tchalt, (target_ulong t0)) DEF_HELPER(target_ulong, do_mftc0_tchalt, (void))
DEF_HELPER(target_ulong, do_mfc0_tccontext, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_tccontext, (void))
DEF_HELPER(target_ulong, do_mftc0_tccontext, (target_ulong t0)) DEF_HELPER(target_ulong, do_mftc0_tccontext, (void))
DEF_HELPER(target_ulong, do_mfc0_tcschedule, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_tcschedule, (void))
DEF_HELPER(target_ulong, do_mftc0_tcschedule, (target_ulong t0)) DEF_HELPER(target_ulong, do_mftc0_tcschedule, (void))
DEF_HELPER(target_ulong, do_mfc0_tcschefback, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_tcschefback, (void))
DEF_HELPER(target_ulong, do_mftc0_tcschefback, (target_ulong t0)) DEF_HELPER(target_ulong, do_mftc0_tcschefback, (void))
DEF_HELPER(target_ulong, do_mfc0_count, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_count, (void))
DEF_HELPER(target_ulong, do_mftc0_entryhi, (target_ulong t0)) DEF_HELPER(target_ulong, do_mftc0_entryhi, (void))
DEF_HELPER(target_ulong, do_mftc0_status, (target_ulong t0)) DEF_HELPER(target_ulong, do_mftc0_status, (void))
DEF_HELPER(target_ulong, do_mfc0_lladdr, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_lladdr, (void))
DEF_HELPER(target_ulong, do_mfc0_watchlo, (target_ulong t0, uint32_t sel)) DEF_HELPER(target_ulong, do_mfc0_watchlo, (uint32_t sel))
DEF_HELPER(target_ulong, do_mfc0_watchhi, (target_ulong t0, uint32_t sel)) DEF_HELPER(target_ulong, do_mfc0_watchhi, (uint32_t sel))
DEF_HELPER(target_ulong, do_mfc0_debug, (target_ulong t0)) DEF_HELPER(target_ulong, do_mfc0_debug, (void))
DEF_HELPER(target_ulong, do_mftc0_debug, (target_ulong t0)) DEF_HELPER(target_ulong, do_mftc0_debug, (void))
#ifdef TARGET_MIPS64 #ifdef TARGET_MIPS64
DEF_HELPER(target_ulong, do_dmfc0_tcrestart, (target_ulong t0)) DEF_HELPER(target_ulong, do_dmfc0_tcrestart, (void))
DEF_HELPER(target_ulong, do_dmfc0_tchalt, (target_ulong t0)) DEF_HELPER(target_ulong, do_dmfc0_tchalt, (void))
DEF_HELPER(target_ulong, do_dmfc0_tccontext, (target_ulong t0)) DEF_HELPER(target_ulong, do_dmfc0_tccontext, (void))
DEF_HELPER(target_ulong, do_dmfc0_tcschedule, (target_ulong t0)) DEF_HELPER(target_ulong, do_dmfc0_tcschedule, (void))
DEF_HELPER(target_ulong, do_dmfc0_tcschefback, (target_ulong t0)) DEF_HELPER(target_ulong, do_dmfc0_tcschefback, (void))
DEF_HELPER(target_ulong, do_dmfc0_lladdr, (target_ulong t0)) DEF_HELPER(target_ulong, do_dmfc0_lladdr, (void))
DEF_HELPER(target_ulong, do_dmfc0_watchlo, (target_ulong t0, uint32_t sel)) DEF_HELPER(target_ulong, do_dmfc0_watchlo, (uint32_t sel))
#endif /* TARGET_MIPS64 */ #endif /* TARGET_MIPS64 */
DEF_HELPER(void, do_mtc0_index, (target_ulong t0)) DEF_HELPER(void, do_mtc0_index, (target_ulong t0))
......
...@@ -650,126 +650,127 @@ void cpu_mips_tlb_flush (CPUState *env, int flush_global) ...@@ -650,126 +650,127 @@ void cpu_mips_tlb_flush (CPUState *env, int flush_global)
#else #else
/* CP0 helpers */ /* CP0 helpers */
target_ulong do_mfc0_mvpcontrol (target_ulong t0) target_ulong do_mfc0_mvpcontrol (void)
{ {
return env->mvp->CP0_MVPControl; return env->mvp->CP0_MVPControl;
} }
target_ulong do_mfc0_mvpconf0 (target_ulong t0) target_ulong do_mfc0_mvpconf0 (void)
{ {
return env->mvp->CP0_MVPConf0; return env->mvp->CP0_MVPConf0;
} }
target_ulong do_mfc0_mvpconf1 (target_ulong t0) target_ulong do_mfc0_mvpconf1 (void)
{ {
return env->mvp->CP0_MVPConf1; return env->mvp->CP0_MVPConf1;
} }
target_ulong do_mfc0_random (target_ulong t0) target_ulong do_mfc0_random (void)
{ {
return (int32_t)cpu_mips_get_random(env); return (int32_t)cpu_mips_get_random(env);
} }
target_ulong do_mfc0_tcstatus (target_ulong t0) target_ulong do_mfc0_tcstatus (void)
{ {
return env->CP0_TCStatus[env->current_tc]; return env->CP0_TCStatus[env->current_tc];
} }
target_ulong do_mftc0_tcstatus(target_ulong t0) target_ulong do_mftc0_tcstatus(void)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
return env->CP0_TCStatus[other_tc]; return env->CP0_TCStatus[other_tc];
} }
target_ulong do_mfc0_tcbind (target_ulong t0) target_ulong do_mfc0_tcbind (void)
{ {
return env->CP0_TCBind[env->current_tc]; return env->CP0_TCBind[env->current_tc];
} }
target_ulong do_mftc0_tcbind(target_ulong t0) target_ulong do_mftc0_tcbind(void)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
return env->CP0_TCBind[other_tc]; return env->CP0_TCBind[other_tc];
} }
target_ulong do_mfc0_tcrestart (target_ulong t0) target_ulong do_mfc0_tcrestart (void)
{ {
return env->PC[env->current_tc]; return env->PC[env->current_tc];
} }
target_ulong do_mftc0_tcrestart(target_ulong t0) target_ulong do_mftc0_tcrestart(void)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
return env->PC[other_tc]; return env->PC[other_tc];
} }
target_ulong do_mfc0_tchalt (target_ulong t0) target_ulong do_mfc0_tchalt (void)
{ {
return env->CP0_TCHalt[env->current_tc]; return env->CP0_TCHalt[env->current_tc];
} }
target_ulong do_mftc0_tchalt(target_ulong t0) target_ulong do_mftc0_tchalt(void)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
return env->CP0_TCHalt[other_tc]; return env->CP0_TCHalt[other_tc];
} }
target_ulong do_mfc0_tccontext (target_ulong t0) target_ulong do_mfc0_tccontext (void)
{ {
return env->CP0_TCContext[env->current_tc]; return env->CP0_TCContext[env->current_tc];
} }
target_ulong do_mftc0_tccontext(target_ulong t0) target_ulong do_mftc0_tccontext(void)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
return env->CP0_TCContext[other_tc]; return env->CP0_TCContext[other_tc];
} }
target_ulong do_mfc0_tcschedule (target_ulong t0) target_ulong do_mfc0_tcschedule (void)
{ {
return env->CP0_TCSchedule[env->current_tc]; return env->CP0_TCSchedule[env->current_tc];
} }
target_ulong do_mftc0_tcschedule(target_ulong t0) target_ulong do_mftc0_tcschedule(void)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
return env->CP0_TCSchedule[other_tc]; return env->CP0_TCSchedule[other_tc];
} }
target_ulong do_mfc0_tcschefback (target_ulong t0) target_ulong do_mfc0_tcschefback (void)
{ {
return env->CP0_TCScheFBack[env->current_tc]; return env->CP0_TCScheFBack[env->current_tc];
} }
target_ulong do_mftc0_tcschefback(target_ulong t0) target_ulong do_mftc0_tcschefback(void)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
return env->CP0_TCScheFBack[other_tc]; return env->CP0_TCScheFBack[other_tc];
} }
target_ulong do_mfc0_count (target_ulong t0) target_ulong do_mfc0_count (void)
{ {
return (int32_t)cpu_mips_get_count(env); return (int32_t)cpu_mips_get_count(env);
} }
target_ulong do_mftc0_entryhi(target_ulong t0) target_ulong do_mftc0_entryhi(void)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
return (env->CP0_EntryHi & ~0xff) | (env->CP0_TCStatus[other_tc] & 0xff); return (env->CP0_EntryHi & ~0xff) | (env->CP0_TCStatus[other_tc] & 0xff);
} }
target_ulong do_mftc0_status(target_ulong t0) target_ulong do_mftc0_status(void)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
uint32_t tcstatus = env->CP0_TCStatus[other_tc]; uint32_t tcstatus = env->CP0_TCStatus[other_tc];
target_ulong t0;
t0 = env->CP0_Status & ~0xf1000018; t0 = env->CP0_Status & ~0xf1000018;
t0 |= tcstatus & (0xf << CP0TCSt_TCU0); t0 |= tcstatus & (0xf << CP0TCSt_TCU0);
...@@ -779,31 +780,31 @@ target_ulong do_mftc0_status(target_ulong t0) ...@@ -779,31 +780,31 @@ target_ulong do_mftc0_status(target_ulong t0)
return t0; return t0;
} }
target_ulong do_mfc0_lladdr (target_ulong t0) target_ulong do_mfc0_lladdr (void)
{ {
return (int32_t)env->CP0_LLAddr >> 4; return (int32_t)env->CP0_LLAddr >> 4;
} }
target_ulong do_mfc0_watchlo (target_ulong t0, uint32_t sel) target_ulong do_mfc0_watchlo (uint32_t sel)
{ {
return (int32_t)env->CP0_WatchLo[sel]; return (int32_t)env->CP0_WatchLo[sel];
} }
target_ulong do_mfc0_watchhi (target_ulong t0, uint32_t sel) target_ulong do_mfc0_watchhi (uint32_t sel)
{ {
return env->CP0_WatchHi[sel]; return env->CP0_WatchHi[sel];
} }
target_ulong do_mfc0_debug (target_ulong t0) target_ulong do_mfc0_debug (void)
{ {
t0 = env->CP0_Debug; target_ulong t0 = env->CP0_Debug;
if (env->hflags & MIPS_HFLAG_DM) if (env->hflags & MIPS_HFLAG_DM)
t0 |= 1 << CP0DB_DM; t0 |= 1 << CP0DB_DM;
return t0; return t0;
} }
target_ulong do_mftc0_debug(target_ulong t0) target_ulong do_mftc0_debug(void)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
...@@ -814,37 +815,37 @@ target_ulong do_mftc0_debug(target_ulong t0) ...@@ -814,37 +815,37 @@ target_ulong do_mftc0_debug(target_ulong t0)
} }
#if defined(TARGET_MIPS64) #if defined(TARGET_MIPS64)
target_ulong do_dmfc0_tcrestart (target_ulong t0) target_ulong do_dmfc0_tcrestart (void)
{ {
return env->PC[env->current_tc]; return env->PC[env->current_tc];
} }
target_ulong do_dmfc0_tchalt (target_ulong t0) target_ulong do_dmfc0_tchalt (void)
{ {
return env->CP0_TCHalt[env->current_tc]; return env->CP0_TCHalt[env->current_tc];
} }
target_ulong do_dmfc0_tccontext (target_ulong t0) target_ulong do_dmfc0_tccontext (void)
{ {
return env->CP0_TCContext[env->current_tc]; return env->CP0_TCContext[env->current_tc];
} }
target_ulong do_dmfc0_tcschedule (target_ulong t0) target_ulong do_dmfc0_tcschedule (void)
{ {
return env->CP0_TCSchedule[env->current_tc]; return env->CP0_TCSchedule[env->current_tc];
} }
target_ulong do_dmfc0_tcschefback (target_ulong t0) target_ulong do_dmfc0_tcschefback (void)
{ {
return env->CP0_TCScheFBack[env->current_tc]; return env->CP0_TCScheFBack[env->current_tc];
} }
target_ulong do_dmfc0_lladdr (target_ulong t0) target_ulong do_dmfc0_lladdr (void)
{ {
return env->CP0_LLAddr >> 4; return env->CP0_LLAddr >> 4;
} }
target_ulong do_dmfc0_watchlo (target_ulong t0, uint32_t sel) target_ulong do_dmfc0_watchlo (uint32_t sel)
{ {
return env->CP0_WatchLo[sel]; return env->CP0_WatchLo[sel];
} }
......
...@@ -423,7 +423,7 @@ enum { ...@@ -423,7 +423,7 @@ enum {
}; };
/* global register indices */ /* global register indices */
static TCGv cpu_env, current_tc_gprs, current_tc_hi, current_fpu, cpu_T[1]; static TCGv cpu_env, current_tc_gprs, current_tc_hi, current_fpu;
/* FPU TNs, global for now. */ /* FPU TNs, global for now. */
static TCGv fpu32_T[3], fpu64_T[3], fpu32h_T[3]; static TCGv fpu32_T[3], fpu64_T[3], fpu32h_T[3];
...@@ -2856,7 +2856,7 @@ static inline void gen_mtc0_store64 (TCGv t, target_ulong off) ...@@ -2856,7 +2856,7 @@ static inline void gen_mtc0_store64 (TCGv t, target_ulong off)
tcg_gen_st_tl(t, cpu_env, off); tcg_gen_st_tl(t, cpu_env, off);
} }
static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) static void gen_mfc0 (CPUState *env, DisasContext *ctx, TCGv t0, int reg, int sel)
{ {
const char *rn = "invalid"; const char *rn = "invalid";
...@@ -2867,22 +2867,22 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -2867,22 +2867,22 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 0: case 0:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Index)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Index));
rn = "Index"; rn = "Index";
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_mvpcontrol, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_mvpcontrol, t0);
rn = "MVPControl"; rn = "MVPControl";
break; break;
case 2: case 2:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_mvpconf0, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_mvpconf0, t0);
rn = "MVPConf0"; rn = "MVPConf0";
break; break;
case 3: case 3:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_mvpconf1, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_mvpconf1, t0);
rn = "MVPConf1"; rn = "MVPConf1";
break; break;
default: default:
...@@ -2892,42 +2892,42 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -2892,42 +2892,42 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 1: case 1:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_mfc0_random, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_random, t0);
rn = "Random"; rn = "Random";
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_VPEControl)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_VPEControl));
rn = "VPEControl"; rn = "VPEControl";
break; break;
case 2: case 2:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_VPEConf0)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_VPEConf0));
rn = "VPEConf0"; rn = "VPEConf0";
break; break;
case 3: case 3:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_VPEConf1)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_VPEConf1));
rn = "VPEConf1"; rn = "VPEConf1";
break; break;
case 4: case 4:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load64(cpu_T[0], offsetof(CPUState, CP0_YQMask)); gen_mfc0_load64(t0, offsetof(CPUState, CP0_YQMask));
rn = "YQMask"; rn = "YQMask";
break; break;
case 5: case 5:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load64(cpu_T[0], offsetof(CPUState, CP0_VPESchedule)); gen_mfc0_load64(t0, offsetof(CPUState, CP0_VPESchedule));
rn = "VPESchedule"; rn = "VPESchedule";
break; break;
case 6: case 6:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load64(cpu_T[0], offsetof(CPUState, CP0_VPEScheFBack)); gen_mfc0_load64(t0, offsetof(CPUState, CP0_VPEScheFBack));
rn = "VPEScheFBack"; rn = "VPEScheFBack";
break; break;
case 7: case 7:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_VPEOpt)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_VPEOpt));
rn = "VPEOpt"; rn = "VPEOpt";
break; break;
default: default:
...@@ -2937,43 +2937,43 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -2937,43 +2937,43 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_EntryLo0)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_EntryLo0));
tcg_gen_ext32s_tl(cpu_T[0], cpu_T[0]); tcg_gen_ext32s_tl(t0, t0);
rn = "EntryLo0"; rn = "EntryLo0";
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_tcstatus, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_tcstatus, t0);
rn = "TCStatus"; rn = "TCStatus";
break; break;
case 2: case 2:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_tcbind, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_tcbind, t0);
rn = "TCBind"; rn = "TCBind";
break; break;
case 3: case 3:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_tcrestart, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_tcrestart, t0);
rn = "TCRestart"; rn = "TCRestart";
break; break;
case 4: case 4:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_tchalt, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_tchalt, t0);
rn = "TCHalt"; rn = "TCHalt";
break; break;
case 5: case 5:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_tccontext, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_tccontext, t0);
rn = "TCContext"; rn = "TCContext";
break; break;
case 6: case 6:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_tcschedule, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_tcschedule, t0);
rn = "TCSchedule"; rn = "TCSchedule";
break; break;
case 7: case 7:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_tcschefback, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_tcschefback, t0);
rn = "TCScheFBack"; rn = "TCScheFBack";
break; break;
default: default:
...@@ -2983,8 +2983,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -2983,8 +2983,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 3: case 3:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_EntryLo1)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_EntryLo1));
tcg_gen_ext32s_tl(cpu_T[0], cpu_T[0]); tcg_gen_ext32s_tl(t0, t0);
rn = "EntryLo1"; rn = "EntryLo1";
break; break;
default: default:
...@@ -2994,12 +2994,12 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -2994,12 +2994,12 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 4: case 4:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_Context)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_Context));
tcg_gen_ext32s_tl(cpu_T[0], cpu_T[0]); tcg_gen_ext32s_tl(t0, t0);
rn = "Context"; rn = "Context";
break; break;
case 1: case 1:
// tcg_gen_helper_1_1(do_mfc0_contextconfig, cpu_T[0], cpu_T[0]); /* SmartMIPS ASE */ // tcg_gen_helper_1_0(do_mfc0_contextconfig, t0); /* SmartMIPS ASE */
rn = "ContextConfig"; rn = "ContextConfig";
// break; // break;
default: default:
...@@ -3009,12 +3009,12 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3009,12 +3009,12 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 5: case 5:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_PageMask)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_PageMask));
rn = "PageMask"; rn = "PageMask";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_PageGrain)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_PageGrain));
rn = "PageGrain"; rn = "PageGrain";
break; break;
default: default:
...@@ -3024,32 +3024,32 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3024,32 +3024,32 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 6: case 6:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Wired)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Wired));
rn = "Wired"; rn = "Wired";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSConf0)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSConf0));
rn = "SRSConf0"; rn = "SRSConf0";
break; break;
case 2: case 2:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSConf1)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSConf1));
rn = "SRSConf1"; rn = "SRSConf1";
break; break;
case 3: case 3:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSConf2)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSConf2));
rn = "SRSConf2"; rn = "SRSConf2";
break; break;
case 4: case 4:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSConf3)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSConf3));
rn = "SRSConf3"; rn = "SRSConf3";
break; break;
case 5: case 5:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSConf4)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSConf4));
rn = "SRSConf4"; rn = "SRSConf4";
break; break;
default: default:
...@@ -3060,7 +3060,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3060,7 +3060,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_HWREna)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_HWREna));
rn = "HWREna"; rn = "HWREna";
break; break;
default: default:
...@@ -3070,8 +3070,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3070,8 +3070,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 8: case 8:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_BadVAddr)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_BadVAddr));
tcg_gen_ext32s_tl(cpu_T[0], cpu_T[0]); tcg_gen_ext32s_tl(t0, t0);
rn = "BadVAddr"; rn = "BadVAddr";
break; break;
default: default:
...@@ -3081,7 +3081,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3081,7 +3081,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 9: case 9:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_mfc0_count, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_count, t0);
rn = "Count"; rn = "Count";
break; break;
/* 6,7 are implementation dependent */ /* 6,7 are implementation dependent */
...@@ -3092,8 +3092,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3092,8 +3092,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 10: case 10:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_EntryHi)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_EntryHi));
tcg_gen_ext32s_tl(cpu_T[0], cpu_T[0]); tcg_gen_ext32s_tl(t0, t0);
rn = "EntryHi"; rn = "EntryHi";
break; break;
default: default:
...@@ -3103,7 +3103,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3103,7 +3103,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 11: case 11:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Compare)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Compare));
rn = "Compare"; rn = "Compare";
break; break;
/* 6,7 are implementation dependent */ /* 6,7 are implementation dependent */
...@@ -3114,22 +3114,22 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3114,22 +3114,22 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 12: case 12:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Status)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Status));
rn = "Status"; rn = "Status";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_IntCtl)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_IntCtl));
rn = "IntCtl"; rn = "IntCtl";
break; break;
case 2: case 2:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSCtl)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSCtl));
rn = "SRSCtl"; rn = "SRSCtl";
break; break;
case 3: case 3:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSMap)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSMap));
rn = "SRSMap"; rn = "SRSMap";
break; break;
default: default:
...@@ -3139,7 +3139,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3139,7 +3139,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 13: case 13:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Cause)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Cause));
rn = "Cause"; rn = "Cause";
break; break;
default: default:
...@@ -3149,8 +3149,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3149,8 +3149,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 14: case 14:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_EPC)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_EPC));
tcg_gen_ext32s_tl(cpu_T[0], cpu_T[0]); tcg_gen_ext32s_tl(t0, t0);
rn = "EPC"; rn = "EPC";
break; break;
default: default:
...@@ -3160,12 +3160,12 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3160,12 +3160,12 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 15: case 15:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_PRid)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_PRid));
rn = "PRid"; rn = "PRid";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_EBase)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_EBase));
rn = "EBase"; rn = "EBase";
break; break;
default: default:
...@@ -3175,29 +3175,29 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3175,29 +3175,29 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 16: case 16:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config0)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config0));
rn = "Config"; rn = "Config";
break; break;
case 1: case 1:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config1)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config1));
rn = "Config1"; rn = "Config1";
break; break;
case 2: case 2:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config2)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config2));
rn = "Config2"; rn = "Config2";
break; break;
case 3: case 3:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config3)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config3));
rn = "Config3"; rn = "Config3";
break; break;
/* 4,5 are reserved */ /* 4,5 are reserved */
/* 6,7 are implementation dependent */ /* 6,7 are implementation dependent */
case 6: case 6:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config6)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config6));
rn = "Config6"; rn = "Config6";
break; break;
case 7: case 7:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config7)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config7));
rn = "Config7"; rn = "Config7";
break; break;
default: default:
...@@ -3207,7 +3207,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3207,7 +3207,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 17: case 17:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_mfc0_lladdr, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_lladdr, t0);
rn = "LLAddr"; rn = "LLAddr";
break; break;
default: default:
...@@ -3217,7 +3217,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3217,7 +3217,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 18: case 18:
switch (sel) { switch (sel) {
case 0 ... 7: case 0 ... 7:
tcg_gen_helper_1_1i(do_mfc0_watchlo, cpu_T[0], cpu_T[0], sel); tcg_gen_helper_1_i(do_mfc0_watchlo, t0, sel);
rn = "WatchLo"; rn = "WatchLo";
break; break;
default: default:
...@@ -3227,7 +3227,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3227,7 +3227,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 19: case 19:
switch (sel) { switch (sel) {
case 0 ...7: case 0 ...7:
tcg_gen_helper_1_1i(do_mfc0_watchhi, cpu_T[0], cpu_T[0], sel); tcg_gen_helper_1_i(do_mfc0_watchhi, t0, sel);
rn = "WatchHi"; rn = "WatchHi";
break; break;
default: default:
...@@ -3239,8 +3239,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3239,8 +3239,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 0: case 0:
#if defined(TARGET_MIPS64) #if defined(TARGET_MIPS64)
check_insn(env, ctx, ISA_MIPS3); check_insn(env, ctx, ISA_MIPS3);
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_XContext)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_XContext));
tcg_gen_ext32s_tl(cpu_T[0], cpu_T[0]); tcg_gen_ext32s_tl(t0, t0);
rn = "XContext"; rn = "XContext";
break; break;
#endif #endif
...@@ -3252,7 +3252,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3252,7 +3252,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
/* Officially reserved, but sel 0 is used for R1x000 framemask */ /* Officially reserved, but sel 0 is used for R1x000 framemask */
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Framemask)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Framemask));
rn = "Framemask"; rn = "Framemask";
break; break;
default: default:
...@@ -3266,23 +3266,23 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3266,23 +3266,23 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 23: case 23:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_mfc0_debug, cpu_T[0], cpu_T[0]); /* EJTAG support */ tcg_gen_helper_1_0(do_mfc0_debug, t0); /* EJTAG support */
rn = "Debug"; rn = "Debug";
break; break;
case 1: case 1:
// tcg_gen_helper_1_1(do_mfc0_tracecontrol, cpu_T[0], cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_1_0(do_mfc0_tracecontrol, t0); /* PDtrace support */
rn = "TraceControl"; rn = "TraceControl";
// break; // break;
case 2: case 2:
// tcg_gen_helper_1_1(do_mfc0_tracecontrol2, cpu_T[0], cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_1_0(do_mfc0_tracecontrol2, t0); /* PDtrace support */
rn = "TraceControl2"; rn = "TraceControl2";
// break; // break;
case 3: case 3:
// tcg_gen_helper_1_1(do_mfc0_usertracedata, cpu_T[0], cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_1_0(do_mfc0_usertracedata, t0); /* PDtrace support */
rn = "UserTraceData"; rn = "UserTraceData";
// break; // break;
case 4: case 4:
// tcg_gen_helper_1_1(do_mfc0_tracebpc, cpu_T[0], cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_1_0(do_mfc0_tracebpc, t0); /* PDtrace support */
rn = "TraceBPC"; rn = "TraceBPC";
// break; // break;
default: default:
...@@ -3293,8 +3293,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3293,8 +3293,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
/* EJTAG support */ /* EJTAG support */
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_DEPC)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_DEPC));
tcg_gen_ext32s_tl(cpu_T[0], cpu_T[0]); tcg_gen_ext32s_tl(t0, t0);
rn = "DEPC"; rn = "DEPC";
break; break;
default: default:
...@@ -3304,35 +3304,35 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3304,35 +3304,35 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 25: case 25:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Performance0)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Performance0));
rn = "Performance0"; rn = "Performance0";
break; break;
case 1: case 1:
// tcg_gen_helper_1_1(do_mfc0_performance1, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_mfc0_performance1, t0);
rn = "Performance1"; rn = "Performance1";
// break; // break;
case 2: case 2:
// tcg_gen_helper_1_1(do_mfc0_performance2, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_mfc0_performance2, t0);
rn = "Performance2"; rn = "Performance2";
// break; // break;
case 3: case 3:
// tcg_gen_helper_1_1(do_mfc0_performance3, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_mfc0_performance3, t0);
rn = "Performance3"; rn = "Performance3";
// break; // break;
case 4: case 4:
// tcg_gen_helper_1_1(do_mfc0_performance4, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_mfc0_performance4, t0);
rn = "Performance4"; rn = "Performance4";
// break; // break;
case 5: case 5:
// tcg_gen_helper_1_1(do_mfc0_performance5, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_mfc0_performance5, t0);
rn = "Performance5"; rn = "Performance5";
// break; // break;
case 6: case 6:
// tcg_gen_helper_1_1(do_mfc0_performance6, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_mfc0_performance6, t0);
rn = "Performance6"; rn = "Performance6";
// break; // break;
case 7: case 7:
// tcg_gen_helper_1_1(do_mfc0_performance7, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_mfc0_performance7, t0);
rn = "Performance7"; rn = "Performance7";
// break; // break;
default: default:
...@@ -3358,14 +3358,14 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3358,14 +3358,14 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
case 4: case 4:
case 6: case 6:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_TagLo)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_TagLo));
rn = "TagLo"; rn = "TagLo";
break; break;
case 1: case 1:
case 3: case 3:
case 5: case 5:
case 7: case 7:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_DataLo)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_DataLo));
rn = "DataLo"; rn = "DataLo";
break; break;
default: default:
...@@ -3378,14 +3378,14 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3378,14 +3378,14 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
case 4: case 4:
case 6: case 6:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_TagHi)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_TagHi));
rn = "TagHi"; rn = "TagHi";
break; break;
case 1: case 1:
case 3: case 3:
case 5: case 5:
case 7: case 7:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_DataHi)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_DataHi));
rn = "DataHi"; rn = "DataHi";
break; break;
default: default:
...@@ -3395,8 +3395,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3395,8 +3395,8 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 30: case 30:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_ErrorEPC)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_ErrorEPC));
tcg_gen_ext32s_tl(cpu_T[0], cpu_T[0]); tcg_gen_ext32s_tl(t0, t0);
rn = "ErrorEPC"; rn = "ErrorEPC";
break; break;
default: default:
...@@ -3407,7 +3407,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3407,7 +3407,7 @@ static void gen_mfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
/* EJTAG support */ /* EJTAG support */
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_DESAVE)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_DESAVE));
rn = "DESAVE"; rn = "DESAVE";
break; break;
default: default:
...@@ -3435,7 +3435,7 @@ die: ...@@ -3435,7 +3435,7 @@ die:
generate_exception(ctx, EXCP_RI); generate_exception(ctx, EXCP_RI);
} }
static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) static void gen_mtc0 (CPUState *env, DisasContext *ctx, TCGv t0, int reg, int sel)
{ {
const char *rn = "invalid"; const char *rn = "invalid";
...@@ -3446,12 +3446,12 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3446,12 +3446,12 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 0: case 0:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_index, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_index, t0);
rn = "Index"; rn = "Index";
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_mvpcontrol, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_mvpcontrol, t0);
rn = "MVPControl"; rn = "MVPControl";
break; break;
case 2: case 2:
...@@ -3476,37 +3476,37 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3476,37 +3476,37 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_vpecontrol, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_vpecontrol, t0);
rn = "VPEControl"; rn = "VPEControl";
break; break;
case 2: case 2:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_vpeconf0, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_vpeconf0, t0);
rn = "VPEConf0"; rn = "VPEConf0";
break; break;
case 3: case 3:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_vpeconf1, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_vpeconf1, t0);
rn = "VPEConf1"; rn = "VPEConf1";
break; break;
case 4: case 4:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_yqmask, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_yqmask, t0);
rn = "YQMask"; rn = "YQMask";
break; break;
case 5: case 5:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mtc0_store64(cpu_T[0], offsetof(CPUState, CP0_VPESchedule)); gen_mtc0_store64(t0, offsetof(CPUState, CP0_VPESchedule));
rn = "VPESchedule"; rn = "VPESchedule";
break; break;
case 6: case 6:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mtc0_store64(cpu_T[0], offsetof(CPUState, CP0_VPEScheFBack)); gen_mtc0_store64(t0, offsetof(CPUState, CP0_VPEScheFBack));
rn = "VPEScheFBack"; rn = "VPEScheFBack";
break; break;
case 7: case 7:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_vpeopt, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_vpeopt, t0);
rn = "VPEOpt"; rn = "VPEOpt";
break; break;
default: default:
...@@ -3516,42 +3516,42 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3516,42 +3516,42 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_entrylo0, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_entrylo0, t0);
rn = "EntryLo0"; rn = "EntryLo0";
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tcstatus, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tcstatus, t0);
rn = "TCStatus"; rn = "TCStatus";
break; break;
case 2: case 2:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tcbind, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tcbind, t0);
rn = "TCBind"; rn = "TCBind";
break; break;
case 3: case 3:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tcrestart, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tcrestart, t0);
rn = "TCRestart"; rn = "TCRestart";
break; break;
case 4: case 4:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tchalt, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tchalt, t0);
rn = "TCHalt"; rn = "TCHalt";
break; break;
case 5: case 5:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tccontext, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tccontext, t0);
rn = "TCContext"; rn = "TCContext";
break; break;
case 6: case 6:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tcschedule, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tcschedule, t0);
rn = "TCSchedule"; rn = "TCSchedule";
break; break;
case 7: case 7:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tcschefback, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tcschefback, t0);
rn = "TCScheFBack"; rn = "TCScheFBack";
break; break;
default: default:
...@@ -3561,7 +3561,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3561,7 +3561,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 3: case 3:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_entrylo1, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_entrylo1, t0);
rn = "EntryLo1"; rn = "EntryLo1";
break; break;
default: default:
...@@ -3571,11 +3571,11 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3571,11 +3571,11 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 4: case 4:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_context, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_context, t0);
rn = "Context"; rn = "Context";
break; break;
case 1: case 1:
// tcg_gen_helper_0_1(do_mtc0_contextconfig, cpu_T[0]); /* SmartMIPS ASE */ // tcg_gen_helper_0_1(do_mtc0_contextconfig, t0); /* SmartMIPS ASE */
rn = "ContextConfig"; rn = "ContextConfig";
// break; // break;
default: default:
...@@ -3585,12 +3585,12 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3585,12 +3585,12 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 5: case 5:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_pagemask, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_pagemask, t0);
rn = "PageMask"; rn = "PageMask";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_pagegrain, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_pagegrain, t0);
rn = "PageGrain"; rn = "PageGrain";
break; break;
default: default:
...@@ -3600,32 +3600,32 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3600,32 +3600,32 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 6: case 6:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_wired, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_wired, t0);
rn = "Wired"; rn = "Wired";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsconf0, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsconf0, t0);
rn = "SRSConf0"; rn = "SRSConf0";
break; break;
case 2: case 2:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsconf1, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsconf1, t0);
rn = "SRSConf1"; rn = "SRSConf1";
break; break;
case 3: case 3:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsconf2, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsconf2, t0);
rn = "SRSConf2"; rn = "SRSConf2";
break; break;
case 4: case 4:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsconf3, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsconf3, t0);
rn = "SRSConf3"; rn = "SRSConf3";
break; break;
case 5: case 5:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsconf4, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsconf4, t0);
rn = "SRSConf4"; rn = "SRSConf4";
break; break;
default: default:
...@@ -3636,7 +3636,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3636,7 +3636,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_hwrena, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_hwrena, t0);
rn = "HWREna"; rn = "HWREna";
break; break;
default: default:
...@@ -3650,7 +3650,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3650,7 +3650,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 9: case 9:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_count, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_count, t0);
rn = "Count"; rn = "Count";
break; break;
/* 6,7 are implementation dependent */ /* 6,7 are implementation dependent */
...@@ -3663,7 +3663,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3663,7 +3663,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 10: case 10:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_entryhi, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_entryhi, t0);
rn = "EntryHi"; rn = "EntryHi";
break; break;
default: default:
...@@ -3673,7 +3673,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3673,7 +3673,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 11: case 11:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_compare, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_compare, t0);
rn = "Compare"; rn = "Compare";
break; break;
/* 6,7 are implementation dependent */ /* 6,7 are implementation dependent */
...@@ -3686,7 +3686,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3686,7 +3686,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 12: case 12:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_status, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_status, t0);
/* BS_STOP isn't good enough here, hflags may have changed. */ /* BS_STOP isn't good enough here, hflags may have changed. */
gen_save_pc(ctx->pc + 4); gen_save_pc(ctx->pc + 4);
ctx->bstate = BS_EXCP; ctx->bstate = BS_EXCP;
...@@ -3694,21 +3694,21 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3694,21 +3694,21 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_intctl, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_intctl, t0);
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "IntCtl"; rn = "IntCtl";
break; break;
case 2: case 2:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsctl, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsctl, t0);
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "SRSCtl"; rn = "SRSCtl";
break; break;
case 3: case 3:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mtc0_store32(cpu_T[0], offsetof(CPUState, CP0_SRSMap)); gen_mtc0_store32(t0, offsetof(CPUState, CP0_SRSMap));
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "SRSMap"; rn = "SRSMap";
...@@ -3720,7 +3720,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3720,7 +3720,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 13: case 13:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_cause, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_cause, t0);
rn = "Cause"; rn = "Cause";
break; break;
default: default:
...@@ -3732,7 +3732,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3732,7 +3732,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 14: case 14:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mtc0_store64(cpu_T[0], offsetof(CPUState, CP0_EPC)); gen_mtc0_store64(t0, offsetof(CPUState, CP0_EPC));
rn = "EPC"; rn = "EPC";
break; break;
default: default:
...@@ -3747,7 +3747,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3747,7 +3747,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_ebase, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_ebase, t0);
rn = "EBase"; rn = "EBase";
break; break;
default: default:
...@@ -3757,7 +3757,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3757,7 +3757,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 16: case 16:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_config0, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_config0, t0);
rn = "Config"; rn = "Config";
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
...@@ -3767,7 +3767,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3767,7 +3767,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
rn = "Config1"; rn = "Config1";
break; break;
case 2: case 2:
tcg_gen_helper_0_1(do_mtc0_config2, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_config2, t0);
rn = "Config2"; rn = "Config2";
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
...@@ -3804,7 +3804,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3804,7 +3804,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 18: case 18:
switch (sel) { switch (sel) {
case 0 ... 7: case 0 ... 7:
tcg_gen_helper_0_1i(do_mtc0_watchlo, cpu_T[0], sel); tcg_gen_helper_0_1i(do_mtc0_watchlo, t0, sel);
rn = "WatchLo"; rn = "WatchLo";
break; break;
default: default:
...@@ -3814,7 +3814,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3814,7 +3814,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 19: case 19:
switch (sel) { switch (sel) {
case 0 ... 7: case 0 ... 7:
tcg_gen_helper_0_1i(do_mtc0_watchhi, cpu_T[0], sel); tcg_gen_helper_0_1i(do_mtc0_watchhi, t0, sel);
rn = "WatchHi"; rn = "WatchHi";
break; break;
default: default:
...@@ -3826,7 +3826,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3826,7 +3826,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 0: case 0:
#if defined(TARGET_MIPS64) #if defined(TARGET_MIPS64)
check_insn(env, ctx, ISA_MIPS3); check_insn(env, ctx, ISA_MIPS3);
tcg_gen_helper_0_1(do_mtc0_xcontext, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_xcontext, t0);
rn = "XContext"; rn = "XContext";
break; break;
#endif #endif
...@@ -3838,7 +3838,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3838,7 +3838,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
/* Officially reserved, but sel 0 is used for R1x000 framemask */ /* Officially reserved, but sel 0 is used for R1x000 framemask */
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_framemask, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_framemask, t0);
rn = "Framemask"; rn = "Framemask";
break; break;
default: default:
...@@ -3852,20 +3852,20 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3852,20 +3852,20 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 23: case 23:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_debug, cpu_T[0]); /* EJTAG support */ tcg_gen_helper_0_1(do_mtc0_debug, t0); /* EJTAG support */
/* BS_STOP isn't good enough here, hflags may have changed. */ /* BS_STOP isn't good enough here, hflags may have changed. */
gen_save_pc(ctx->pc + 4); gen_save_pc(ctx->pc + 4);
ctx->bstate = BS_EXCP; ctx->bstate = BS_EXCP;
rn = "Debug"; rn = "Debug";
break; break;
case 1: case 1:
// tcg_gen_helper_0_1(do_mtc0_tracecontrol, cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_0_1(do_mtc0_tracecontrol, t0); /* PDtrace support */
rn = "TraceControl"; rn = "TraceControl";
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
// break; // break;
case 2: case 2:
// tcg_gen_helper_0_1(do_mtc0_tracecontrol2, cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_0_1(do_mtc0_tracecontrol2, t0); /* PDtrace support */
rn = "TraceControl2"; rn = "TraceControl2";
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
...@@ -3873,13 +3873,13 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3873,13 +3873,13 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 3: case 3:
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
// tcg_gen_helper_0_1(do_mtc0_usertracedata, cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_0_1(do_mtc0_usertracedata, t0); /* PDtrace support */
rn = "UserTraceData"; rn = "UserTraceData";
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
// break; // break;
case 4: case 4:
// tcg_gen_helper_0_1(do_mtc0_tracebpc, cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_0_1(do_mtc0_tracebpc, t0); /* PDtrace support */
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "TraceBPC"; rn = "TraceBPC";
...@@ -3892,7 +3892,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3892,7 +3892,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
/* EJTAG support */ /* EJTAG support */
gen_mtc0_store64(cpu_T[0], offsetof(CPUState, CP0_DEPC)); gen_mtc0_store64(t0, offsetof(CPUState, CP0_DEPC));
rn = "DEPC"; rn = "DEPC";
break; break;
default: default:
...@@ -3902,35 +3902,35 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3902,35 +3902,35 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 25: case 25:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_performance0, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_performance0, t0);
rn = "Performance0"; rn = "Performance0";
break; break;
case 1: case 1:
// tcg_gen_helper_0_1(do_mtc0_performance1, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance1, t0);
rn = "Performance1"; rn = "Performance1";
// break; // break;
case 2: case 2:
// tcg_gen_helper_0_1(do_mtc0_performance2, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance2, t0);
rn = "Performance2"; rn = "Performance2";
// break; // break;
case 3: case 3:
// tcg_gen_helper_0_1(do_mtc0_performance3, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance3, t0);
rn = "Performance3"; rn = "Performance3";
// break; // break;
case 4: case 4:
// tcg_gen_helper_0_1(do_mtc0_performance4, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance4, t0);
rn = "Performance4"; rn = "Performance4";
// break; // break;
case 5: case 5:
// tcg_gen_helper_0_1(do_mtc0_performance5, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance5, t0);
rn = "Performance5"; rn = "Performance5";
// break; // break;
case 6: case 6:
// tcg_gen_helper_0_1(do_mtc0_performance6, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance6, t0);
rn = "Performance6"; rn = "Performance6";
// break; // break;
case 7: case 7:
// tcg_gen_helper_0_1(do_mtc0_performance7, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance7, t0);
rn = "Performance7"; rn = "Performance7";
// break; // break;
default: default:
...@@ -3957,14 +3957,14 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3957,14 +3957,14 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
case 4: case 4:
case 6: case 6:
tcg_gen_helper_0_1(do_mtc0_taglo, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_taglo, t0);
rn = "TagLo"; rn = "TagLo";
break; break;
case 1: case 1:
case 3: case 3:
case 5: case 5:
case 7: case 7:
tcg_gen_helper_0_1(do_mtc0_datalo, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_datalo, t0);
rn = "DataLo"; rn = "DataLo";
break; break;
default: default:
...@@ -3977,14 +3977,14 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3977,14 +3977,14 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
case 4: case 4:
case 6: case 6:
tcg_gen_helper_0_1(do_mtc0_taghi, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_taghi, t0);
rn = "TagHi"; rn = "TagHi";
break; break;
case 1: case 1:
case 3: case 3:
case 5: case 5:
case 7: case 7:
tcg_gen_helper_0_1(do_mtc0_datahi, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_datahi, t0);
rn = "DataHi"; rn = "DataHi";
break; break;
default: default:
...@@ -3995,7 +3995,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -3995,7 +3995,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 30: case 30:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mtc0_store64(cpu_T[0], offsetof(CPUState, CP0_ErrorEPC)); gen_mtc0_store64(t0, offsetof(CPUState, CP0_ErrorEPC));
rn = "ErrorEPC"; rn = "ErrorEPC";
break; break;
default: default:
...@@ -4006,7 +4006,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4006,7 +4006,7 @@ static void gen_mtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
/* EJTAG support */ /* EJTAG support */
gen_mtc0_store32(cpu_T[0], offsetof(CPUState, CP0_DESAVE)); gen_mtc0_store32(t0, offsetof(CPUState, CP0_DESAVE));
rn = "DESAVE"; rn = "DESAVE";
break; break;
default: default:
...@@ -4037,7 +4037,7 @@ die: ...@@ -4037,7 +4037,7 @@ die:
} }
#if defined(TARGET_MIPS64) #if defined(TARGET_MIPS64)
static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) static void gen_dmfc0 (CPUState *env, DisasContext *ctx, TCGv t0, int reg, int sel)
{ {
const char *rn = "invalid"; const char *rn = "invalid";
...@@ -4048,22 +4048,22 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4048,22 +4048,22 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 0: case 0:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Index)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Index));
rn = "Index"; rn = "Index";
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_mvpcontrol, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_mvpcontrol, t0);
rn = "MVPControl"; rn = "MVPControl";
break; break;
case 2: case 2:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_mvpconf0, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_mvpconf0, t0);
rn = "MVPConf0"; rn = "MVPConf0";
break; break;
case 3: case 3:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_mvpconf1, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_mvpconf1, t0);
rn = "MVPConf1"; rn = "MVPConf1";
break; break;
default: default:
...@@ -4073,42 +4073,42 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4073,42 +4073,42 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 1: case 1:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_mfc0_random, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_random, t0);
rn = "Random"; rn = "Random";
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_VPEControl)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_VPEControl));
rn = "VPEControl"; rn = "VPEControl";
break; break;
case 2: case 2:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_VPEConf0)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_VPEConf0));
rn = "VPEConf0"; rn = "VPEConf0";
break; break;
case 3: case 3:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_VPEConf1)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_VPEConf1));
rn = "VPEConf1"; rn = "VPEConf1";
break; break;
case 4: case 4:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_YQMask)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_YQMask));
rn = "YQMask"; rn = "YQMask";
break; break;
case 5: case 5:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_VPESchedule)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_VPESchedule));
rn = "VPESchedule"; rn = "VPESchedule";
break; break;
case 6: case 6:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_VPEScheFBack)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_VPEScheFBack));
rn = "VPEScheFBack"; rn = "VPEScheFBack";
break; break;
case 7: case 7:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_VPEOpt)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_VPEOpt));
rn = "VPEOpt"; rn = "VPEOpt";
break; break;
default: default:
...@@ -4118,42 +4118,42 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4118,42 +4118,42 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_EntryLo0)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_EntryLo0));
rn = "EntryLo0"; rn = "EntryLo0";
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_tcstatus, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_tcstatus, t0);
rn = "TCStatus"; rn = "TCStatus";
break; break;
case 2: case 2:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_mfc0_tcbind, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_tcbind, t0);
rn = "TCBind"; rn = "TCBind";
break; break;
case 3: case 3:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_dmfc0_tcrestart, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_dmfc0_tcrestart, t0);
rn = "TCRestart"; rn = "TCRestart";
break; break;
case 4: case 4:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_dmfc0_tchalt, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_dmfc0_tchalt, t0);
rn = "TCHalt"; rn = "TCHalt";
break; break;
case 5: case 5:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_dmfc0_tccontext, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_dmfc0_tccontext, t0);
rn = "TCContext"; rn = "TCContext";
break; break;
case 6: case 6:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_dmfc0_tcschedule, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_dmfc0_tcschedule, t0);
rn = "TCSchedule"; rn = "TCSchedule";
break; break;
case 7: case 7:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_1_1(do_dmfc0_tcschefback, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_dmfc0_tcschefback, t0);
rn = "TCScheFBack"; rn = "TCScheFBack";
break; break;
default: default:
...@@ -4163,7 +4163,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4163,7 +4163,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 3: case 3:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_EntryLo1)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_EntryLo1));
rn = "EntryLo1"; rn = "EntryLo1";
break; break;
default: default:
...@@ -4173,11 +4173,11 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4173,11 +4173,11 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 4: case 4:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_Context)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_Context));
rn = "Context"; rn = "Context";
break; break;
case 1: case 1:
// tcg_gen_helper_1_1(do_dmfc0_contextconfig, cpu_T[0], cpu_T[0]); /* SmartMIPS ASE */ // tcg_gen_helper_1_0(do_dmfc0_contextconfig, t0); /* SmartMIPS ASE */
rn = "ContextConfig"; rn = "ContextConfig";
// break; // break;
default: default:
...@@ -4187,12 +4187,12 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4187,12 +4187,12 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 5: case 5:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_PageMask)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_PageMask));
rn = "PageMask"; rn = "PageMask";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_PageGrain)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_PageGrain));
rn = "PageGrain"; rn = "PageGrain";
break; break;
default: default:
...@@ -4202,32 +4202,32 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4202,32 +4202,32 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 6: case 6:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Wired)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Wired));
rn = "Wired"; rn = "Wired";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSConf0)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSConf0));
rn = "SRSConf0"; rn = "SRSConf0";
break; break;
case 2: case 2:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSConf1)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSConf1));
rn = "SRSConf1"; rn = "SRSConf1";
break; break;
case 3: case 3:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSConf2)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSConf2));
rn = "SRSConf2"; rn = "SRSConf2";
break; break;
case 4: case 4:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSConf3)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSConf3));
rn = "SRSConf3"; rn = "SRSConf3";
break; break;
case 5: case 5:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSConf4)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSConf4));
rn = "SRSConf4"; rn = "SRSConf4";
break; break;
default: default:
...@@ -4238,7 +4238,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4238,7 +4238,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_HWREna)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_HWREna));
rn = "HWREna"; rn = "HWREna";
break; break;
default: default:
...@@ -4248,7 +4248,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4248,7 +4248,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 8: case 8:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_BadVAddr)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_BadVAddr));
rn = "BadVAddr"; rn = "BadVAddr";
break; break;
default: default:
...@@ -4258,7 +4258,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4258,7 +4258,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 9: case 9:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_mfc0_count, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_mfc0_count, t0);
rn = "Count"; rn = "Count";
break; break;
/* 6,7 are implementation dependent */ /* 6,7 are implementation dependent */
...@@ -4269,7 +4269,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4269,7 +4269,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 10: case 10:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_EntryHi)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_EntryHi));
rn = "EntryHi"; rn = "EntryHi";
break; break;
default: default:
...@@ -4279,7 +4279,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4279,7 +4279,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 11: case 11:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Compare)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Compare));
rn = "Compare"; rn = "Compare";
break; break;
/* 6,7 are implementation dependent */ /* 6,7 are implementation dependent */
...@@ -4290,22 +4290,22 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4290,22 +4290,22 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 12: case 12:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Status)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Status));
rn = "Status"; rn = "Status";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_IntCtl)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_IntCtl));
rn = "IntCtl"; rn = "IntCtl";
break; break;
case 2: case 2:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSCtl)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSCtl));
rn = "SRSCtl"; rn = "SRSCtl";
break; break;
case 3: case 3:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_SRSMap)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_SRSMap));
rn = "SRSMap"; rn = "SRSMap";
break; break;
default: default:
...@@ -4315,7 +4315,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4315,7 +4315,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 13: case 13:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Cause)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Cause));
rn = "Cause"; rn = "Cause";
break; break;
default: default:
...@@ -4325,7 +4325,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4325,7 +4325,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 14: case 14:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_EPC)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_EPC));
rn = "EPC"; rn = "EPC";
break; break;
default: default:
...@@ -4335,12 +4335,12 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4335,12 +4335,12 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 15: case 15:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_PRid)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_PRid));
rn = "PRid"; rn = "PRid";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_EBase)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_EBase));
rn = "EBase"; rn = "EBase";
break; break;
default: default:
...@@ -4350,28 +4350,28 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4350,28 +4350,28 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 16: case 16:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config0)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config0));
rn = "Config"; rn = "Config";
break; break;
case 1: case 1:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config1)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config1));
rn = "Config1"; rn = "Config1";
break; break;
case 2: case 2:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config2)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config2));
rn = "Config2"; rn = "Config2";
break; break;
case 3: case 3:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config3)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config3));
rn = "Config3"; rn = "Config3";
break; break;
/* 6,7 are implementation dependent */ /* 6,7 are implementation dependent */
case 6: case 6:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config6)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config6));
rn = "Config6"; rn = "Config6";
break; break;
case 7: case 7:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Config7)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Config7));
rn = "Config7"; rn = "Config7";
break; break;
default: default:
...@@ -4381,7 +4381,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4381,7 +4381,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 17: case 17:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_dmfc0_lladdr, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_0(do_dmfc0_lladdr, t0);
rn = "LLAddr"; rn = "LLAddr";
break; break;
default: default:
...@@ -4391,7 +4391,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4391,7 +4391,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 18: case 18:
switch (sel) { switch (sel) {
case 0 ... 7: case 0 ... 7:
tcg_gen_helper_1_1i(do_dmfc0_watchlo, cpu_T[0], cpu_T[0], sel); tcg_gen_helper_1_i(do_dmfc0_watchlo, t0, sel);
rn = "WatchLo"; rn = "WatchLo";
break; break;
default: default:
...@@ -4401,7 +4401,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4401,7 +4401,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 19: case 19:
switch (sel) { switch (sel) {
case 0 ... 7: case 0 ... 7:
tcg_gen_helper_1_1i(do_mfc0_watchhi, cpu_T[0], cpu_T[0], sel); tcg_gen_helper_1_i(do_mfc0_watchhi, t0, sel);
rn = "WatchHi"; rn = "WatchHi";
break; break;
default: default:
...@@ -4412,7 +4412,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4412,7 +4412,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
check_insn(env, ctx, ISA_MIPS3); check_insn(env, ctx, ISA_MIPS3);
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_XContext)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_XContext));
rn = "XContext"; rn = "XContext";
break; break;
default: default:
...@@ -4423,7 +4423,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4423,7 +4423,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
/* Officially reserved, but sel 0 is used for R1x000 framemask */ /* Officially reserved, but sel 0 is used for R1x000 framemask */
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Framemask)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Framemask));
rn = "Framemask"; rn = "Framemask";
break; break;
default: default:
...@@ -4437,23 +4437,23 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4437,23 +4437,23 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 23: case 23:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_mfc0_debug, cpu_T[0], cpu_T[0]); /* EJTAG support */ tcg_gen_helper_1_0(do_mfc0_debug, t0); /* EJTAG support */
rn = "Debug"; rn = "Debug";
break; break;
case 1: case 1:
// tcg_gen_helper_1_1(do_dmfc0_tracecontrol, cpu_T[0], cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_1_0(do_dmfc0_tracecontrol, t0); /* PDtrace support */
rn = "TraceControl"; rn = "TraceControl";
// break; // break;
case 2: case 2:
// tcg_gen_helper_1_1(do_dmfc0_tracecontrol2, cpu_T[0], cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_1_0(do_dmfc0_tracecontrol2, t0); /* PDtrace support */
rn = "TraceControl2"; rn = "TraceControl2";
// break; // break;
case 3: case 3:
// tcg_gen_helper_1_1(do_dmfc0_usertracedata, cpu_T[0], cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_1_0(do_dmfc0_usertracedata, t0); /* PDtrace support */
rn = "UserTraceData"; rn = "UserTraceData";
// break; // break;
case 4: case 4:
// tcg_gen_helper_1_1(do_dmfc0_tracebpc, cpu_T[0], cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_1_0(do_dmfc0_tracebpc, t0); /* PDtrace support */
rn = "TraceBPC"; rn = "TraceBPC";
// break; // break;
default: default:
...@@ -4464,7 +4464,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4464,7 +4464,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
/* EJTAG support */ /* EJTAG support */
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_DEPC)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_DEPC));
rn = "DEPC"; rn = "DEPC";
break; break;
default: default:
...@@ -4474,35 +4474,35 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4474,35 +4474,35 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 25: case 25:
switch (sel) { switch (sel) {
case 0: case 0:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_Performance0)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_Performance0));
rn = "Performance0"; rn = "Performance0";
break; break;
case 1: case 1:
// tcg_gen_helper_1_1(do_dmfc0_performance1, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_dmfc0_performance1, t0);
rn = "Performance1"; rn = "Performance1";
// break; // break;
case 2: case 2:
// tcg_gen_helper_1_1(do_dmfc0_performance2, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_dmfc0_performance2, t0);
rn = "Performance2"; rn = "Performance2";
// break; // break;
case 3: case 3:
// tcg_gen_helper_1_1(do_dmfc0_performance3, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_dmfc0_performance3, t0);
rn = "Performance3"; rn = "Performance3";
// break; // break;
case 4: case 4:
// tcg_gen_helper_1_1(do_dmfc0_performance4, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_dmfc0_performance4, t0);
rn = "Performance4"; rn = "Performance4";
// break; // break;
case 5: case 5:
// tcg_gen_helper_1_1(do_dmfc0_performance5, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_dmfc0_performance5, t0);
rn = "Performance5"; rn = "Performance5";
// break; // break;
case 6: case 6:
// tcg_gen_helper_1_1(do_dmfc0_performance6, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_dmfc0_performance6, t0);
rn = "Performance6"; rn = "Performance6";
// break; // break;
case 7: case 7:
// tcg_gen_helper_1_1(do_dmfc0_performance7, cpu_T[0], cpu_T[0]); // tcg_gen_helper_1_0(do_dmfc0_performance7, t0);
rn = "Performance7"; rn = "Performance7";
// break; // break;
default: default:
...@@ -4528,14 +4528,14 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4528,14 +4528,14 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
case 4: case 4:
case 6: case 6:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_TagLo)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_TagLo));
rn = "TagLo"; rn = "TagLo";
break; break;
case 1: case 1:
case 3: case 3:
case 5: case 5:
case 7: case 7:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_DataLo)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_DataLo));
rn = "DataLo"; rn = "DataLo";
break; break;
default: default:
...@@ -4548,14 +4548,14 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4548,14 +4548,14 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
case 4: case 4:
case 6: case 6:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_TagHi)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_TagHi));
rn = "TagHi"; rn = "TagHi";
break; break;
case 1: case 1:
case 3: case 3:
case 5: case 5:
case 7: case 7:
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_DataHi)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_DataHi));
rn = "DataHi"; rn = "DataHi";
break; break;
default: default:
...@@ -4565,7 +4565,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4565,7 +4565,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 30: case 30:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_ld_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_ErrorEPC)); tcg_gen_ld_tl(t0, cpu_env, offsetof(CPUState, CP0_ErrorEPC));
rn = "ErrorEPC"; rn = "ErrorEPC";
break; break;
default: default:
...@@ -4576,7 +4576,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4576,7 +4576,7 @@ static void gen_dmfc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
/* EJTAG support */ /* EJTAG support */
gen_mfc0_load32(cpu_T[0], offsetof(CPUState, CP0_DESAVE)); gen_mfc0_load32(t0, offsetof(CPUState, CP0_DESAVE));
rn = "DESAVE"; rn = "DESAVE";
break; break;
default: default:
...@@ -4604,7 +4604,7 @@ die: ...@@ -4604,7 +4604,7 @@ die:
generate_exception(ctx, EXCP_RI); generate_exception(ctx, EXCP_RI);
} }
static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) static void gen_dmtc0 (CPUState *env, DisasContext *ctx, TCGv t0, int reg, int sel)
{ {
const char *rn = "invalid"; const char *rn = "invalid";
...@@ -4615,12 +4615,12 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4615,12 +4615,12 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 0: case 0:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_index, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_index, t0);
rn = "Index"; rn = "Index";
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_mvpcontrol, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_mvpcontrol, t0);
rn = "MVPControl"; rn = "MVPControl";
break; break;
case 2: case 2:
...@@ -4645,37 +4645,37 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4645,37 +4645,37 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_vpecontrol, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_vpecontrol, t0);
rn = "VPEControl"; rn = "VPEControl";
break; break;
case 2: case 2:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_vpeconf0, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_vpeconf0, t0);
rn = "VPEConf0"; rn = "VPEConf0";
break; break;
case 3: case 3:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_vpeconf1, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_vpeconf1, t0);
rn = "VPEConf1"; rn = "VPEConf1";
break; break;
case 4: case 4:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_yqmask, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_yqmask, t0);
rn = "YQMask"; rn = "YQMask";
break; break;
case 5: case 5:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_st_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_VPESchedule)); tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, CP0_VPESchedule));
rn = "VPESchedule"; rn = "VPESchedule";
break; break;
case 6: case 6:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_st_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_VPEScheFBack)); tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, CP0_VPEScheFBack));
rn = "VPEScheFBack"; rn = "VPEScheFBack";
break; break;
case 7: case 7:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_vpeopt, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_vpeopt, t0);
rn = "VPEOpt"; rn = "VPEOpt";
break; break;
default: default:
...@@ -4685,42 +4685,42 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4685,42 +4685,42 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_entrylo0, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_entrylo0, t0);
rn = "EntryLo0"; rn = "EntryLo0";
break; break;
case 1: case 1:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tcstatus, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tcstatus, t0);
rn = "TCStatus"; rn = "TCStatus";
break; break;
case 2: case 2:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tcbind, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tcbind, t0);
rn = "TCBind"; rn = "TCBind";
break; break;
case 3: case 3:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tcrestart, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tcrestart, t0);
rn = "TCRestart"; rn = "TCRestart";
break; break;
case 4: case 4:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tchalt, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tchalt, t0);
rn = "TCHalt"; rn = "TCHalt";
break; break;
case 5: case 5:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tccontext, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tccontext, t0);
rn = "TCContext"; rn = "TCContext";
break; break;
case 6: case 6:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tcschedule, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tcschedule, t0);
rn = "TCSchedule"; rn = "TCSchedule";
break; break;
case 7: case 7:
check_insn(env, ctx, ASE_MT); check_insn(env, ctx, ASE_MT);
tcg_gen_helper_0_1(do_mtc0_tcschefback, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_tcschefback, t0);
rn = "TCScheFBack"; rn = "TCScheFBack";
break; break;
default: default:
...@@ -4730,7 +4730,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4730,7 +4730,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 3: case 3:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_entrylo1, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_entrylo1, t0);
rn = "EntryLo1"; rn = "EntryLo1";
break; break;
default: default:
...@@ -4740,11 +4740,11 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4740,11 +4740,11 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 4: case 4:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_context, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_context, t0);
rn = "Context"; rn = "Context";
break; break;
case 1: case 1:
// tcg_gen_helper_0_1(do_mtc0_contextconfig, cpu_T[0]); /* SmartMIPS ASE */ // tcg_gen_helper_0_1(do_mtc0_contextconfig, t0); /* SmartMIPS ASE */
rn = "ContextConfig"; rn = "ContextConfig";
// break; // break;
default: default:
...@@ -4754,12 +4754,12 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4754,12 +4754,12 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 5: case 5:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_pagemask, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_pagemask, t0);
rn = "PageMask"; rn = "PageMask";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_pagegrain, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_pagegrain, t0);
rn = "PageGrain"; rn = "PageGrain";
break; break;
default: default:
...@@ -4769,32 +4769,32 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4769,32 +4769,32 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 6: case 6:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_wired, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_wired, t0);
rn = "Wired"; rn = "Wired";
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsconf0, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsconf0, t0);
rn = "SRSConf0"; rn = "SRSConf0";
break; break;
case 2: case 2:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsconf1, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsconf1, t0);
rn = "SRSConf1"; rn = "SRSConf1";
break; break;
case 3: case 3:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsconf2, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsconf2, t0);
rn = "SRSConf2"; rn = "SRSConf2";
break; break;
case 4: case 4:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsconf3, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsconf3, t0);
rn = "SRSConf3"; rn = "SRSConf3";
break; break;
case 5: case 5:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsconf4, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsconf4, t0);
rn = "SRSConf4"; rn = "SRSConf4";
break; break;
default: default:
...@@ -4805,7 +4805,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4805,7 +4805,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_hwrena, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_hwrena, t0);
rn = "HWREna"; rn = "HWREna";
break; break;
default: default:
...@@ -4819,7 +4819,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4819,7 +4819,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 9: case 9:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_count, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_count, t0);
rn = "Count"; rn = "Count";
break; break;
/* 6,7 are implementation dependent */ /* 6,7 are implementation dependent */
...@@ -4832,7 +4832,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4832,7 +4832,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 10: case 10:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_entryhi, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_entryhi, t0);
rn = "EntryHi"; rn = "EntryHi";
break; break;
default: default:
...@@ -4842,7 +4842,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4842,7 +4842,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 11: case 11:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_compare, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_compare, t0);
rn = "Compare"; rn = "Compare";
break; break;
/* 6,7 are implementation dependent */ /* 6,7 are implementation dependent */
...@@ -4855,7 +4855,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4855,7 +4855,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 12: case 12:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_status, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_status, t0);
/* BS_STOP isn't good enough here, hflags may have changed. */ /* BS_STOP isn't good enough here, hflags may have changed. */
gen_save_pc(ctx->pc + 4); gen_save_pc(ctx->pc + 4);
ctx->bstate = BS_EXCP; ctx->bstate = BS_EXCP;
...@@ -4863,21 +4863,21 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4863,21 +4863,21 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_intctl, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_intctl, t0);
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "IntCtl"; rn = "IntCtl";
break; break;
case 2: case 2:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_srsctl, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_srsctl, t0);
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "SRSCtl"; rn = "SRSCtl";
break; break;
case 3: case 3:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
gen_mtc0_store32(cpu_T[0], offsetof(CPUState, CP0_SRSMap)); gen_mtc0_store32(t0, offsetof(CPUState, CP0_SRSMap));
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "SRSMap"; rn = "SRSMap";
...@@ -4889,7 +4889,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4889,7 +4889,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 13: case 13:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_cause, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_cause, t0);
rn = "Cause"; rn = "Cause";
break; break;
default: default:
...@@ -4901,7 +4901,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4901,7 +4901,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 14: case 14:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_st_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_EPC)); tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, CP0_EPC));
rn = "EPC"; rn = "EPC";
break; break;
default: default:
...@@ -4916,7 +4916,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4916,7 +4916,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
break; break;
case 1: case 1:
check_insn(env, ctx, ISA_MIPS32R2); check_insn(env, ctx, ISA_MIPS32R2);
tcg_gen_helper_0_1(do_mtc0_ebase, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_ebase, t0);
rn = "EBase"; rn = "EBase";
break; break;
default: default:
...@@ -4926,7 +4926,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4926,7 +4926,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 16: case 16:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_config0, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_config0, t0);
rn = "Config"; rn = "Config";
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
...@@ -4936,7 +4936,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4936,7 +4936,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
rn = "Config1"; rn = "Config1";
break; break;
case 2: case 2:
tcg_gen_helper_0_1(do_mtc0_config2, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_config2, t0);
rn = "Config2"; rn = "Config2";
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
...@@ -4964,7 +4964,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4964,7 +4964,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 18: case 18:
switch (sel) { switch (sel) {
case 0 ... 7: case 0 ... 7:
tcg_gen_helper_0_1i(do_mtc0_watchlo, cpu_T[0], sel); tcg_gen_helper_0_1i(do_mtc0_watchlo, t0, sel);
rn = "WatchLo"; rn = "WatchLo";
break; break;
default: default:
...@@ -4974,7 +4974,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4974,7 +4974,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 19: case 19:
switch (sel) { switch (sel) {
case 0 ... 7: case 0 ... 7:
tcg_gen_helper_0_1i(do_mtc0_watchhi, cpu_T[0], sel); tcg_gen_helper_0_1i(do_mtc0_watchhi, t0, sel);
rn = "WatchHi"; rn = "WatchHi";
break; break;
default: default:
...@@ -4985,7 +4985,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4985,7 +4985,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
check_insn(env, ctx, ISA_MIPS3); check_insn(env, ctx, ISA_MIPS3);
tcg_gen_helper_0_1(do_mtc0_xcontext, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_xcontext, t0);
rn = "XContext"; rn = "XContext";
break; break;
default: default:
...@@ -4996,7 +4996,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -4996,7 +4996,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
/* Officially reserved, but sel 0 is used for R1x000 framemask */ /* Officially reserved, but sel 0 is used for R1x000 framemask */
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_framemask, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_framemask, t0);
rn = "Framemask"; rn = "Framemask";
break; break;
default: default:
...@@ -5010,32 +5010,32 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -5010,32 +5010,32 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 23: case 23:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_debug, cpu_T[0]); /* EJTAG support */ tcg_gen_helper_0_1(do_mtc0_debug, t0); /* EJTAG support */
/* BS_STOP isn't good enough here, hflags may have changed. */ /* BS_STOP isn't good enough here, hflags may have changed. */
gen_save_pc(ctx->pc + 4); gen_save_pc(ctx->pc + 4);
ctx->bstate = BS_EXCP; ctx->bstate = BS_EXCP;
rn = "Debug"; rn = "Debug";
break; break;
case 1: case 1:
// tcg_gen_helper_0_1(do_mtc0_tracecontrol, cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_0_1(do_mtc0_tracecontrol, t0); /* PDtrace support */
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "TraceControl"; rn = "TraceControl";
// break; // break;
case 2: case 2:
// tcg_gen_helper_0_1(do_mtc0_tracecontrol2, cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_0_1(do_mtc0_tracecontrol2, t0); /* PDtrace support */
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "TraceControl2"; rn = "TraceControl2";
// break; // break;
case 3: case 3:
// tcg_gen_helper_0_1(do_mtc0_usertracedata, cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_0_1(do_mtc0_usertracedata, t0); /* PDtrace support */
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "UserTraceData"; rn = "UserTraceData";
// break; // break;
case 4: case 4:
// tcg_gen_helper_0_1(do_mtc0_tracebpc, cpu_T[0]); /* PDtrace support */ // tcg_gen_helper_0_1(do_mtc0_tracebpc, t0); /* PDtrace support */
/* Stop translation as we may have switched the execution mode */ /* Stop translation as we may have switched the execution mode */
ctx->bstate = BS_STOP; ctx->bstate = BS_STOP;
rn = "TraceBPC"; rn = "TraceBPC";
...@@ -5048,7 +5048,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -5048,7 +5048,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
/* EJTAG support */ /* EJTAG support */
tcg_gen_st_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_DEPC)); tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, CP0_DEPC));
rn = "DEPC"; rn = "DEPC";
break; break;
default: default:
...@@ -5058,35 +5058,35 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -5058,35 +5058,35 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 25: case 25:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mtc0_performance0, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_performance0, t0);
rn = "Performance0"; rn = "Performance0";
break; break;
case 1: case 1:
// tcg_gen_helper_0_1(do_mtc0_performance1, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance1, t0);
rn = "Performance1"; rn = "Performance1";
// break; // break;
case 2: case 2:
// tcg_gen_helper_0_1(do_mtc0_performance2, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance2, t0);
rn = "Performance2"; rn = "Performance2";
// break; // break;
case 3: case 3:
// tcg_gen_helper_0_1(do_mtc0_performance3, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance3, t0);
rn = "Performance3"; rn = "Performance3";
// break; // break;
case 4: case 4:
// tcg_gen_helper_0_1(do_mtc0_performance4, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance4, t0);
rn = "Performance4"; rn = "Performance4";
// break; // break;
case 5: case 5:
// tcg_gen_helper_0_1(do_mtc0_performance5, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance5, t0);
rn = "Performance5"; rn = "Performance5";
// break; // break;
case 6: case 6:
// tcg_gen_helper_0_1(do_mtc0_performance6, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance6, t0);
rn = "Performance6"; rn = "Performance6";
// break; // break;
case 7: case 7:
// tcg_gen_helper_0_1(do_mtc0_performance7, cpu_T[0]); // tcg_gen_helper_0_1(do_mtc0_performance7, t0);
rn = "Performance7"; rn = "Performance7";
// break; // break;
default: default:
...@@ -5113,14 +5113,14 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -5113,14 +5113,14 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
case 4: case 4:
case 6: case 6:
tcg_gen_helper_0_1(do_mtc0_taglo, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_taglo, t0);
rn = "TagLo"; rn = "TagLo";
break; break;
case 1: case 1:
case 3: case 3:
case 5: case 5:
case 7: case 7:
tcg_gen_helper_0_1(do_mtc0_datalo, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_datalo, t0);
rn = "DataLo"; rn = "DataLo";
break; break;
default: default:
...@@ -5133,14 +5133,14 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -5133,14 +5133,14 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 2: case 2:
case 4: case 4:
case 6: case 6:
tcg_gen_helper_0_1(do_mtc0_taghi, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_taghi, t0);
rn = "TagHi"; rn = "TagHi";
break; break;
case 1: case 1:
case 3: case 3:
case 5: case 5:
case 7: case 7:
tcg_gen_helper_0_1(do_mtc0_datahi, cpu_T[0]); tcg_gen_helper_0_1(do_mtc0_datahi, t0);
rn = "DataHi"; rn = "DataHi";
break; break;
default: default:
...@@ -5151,7 +5151,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -5151,7 +5151,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
case 30: case 30:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_st_tl(cpu_T[0], cpu_env, offsetof(CPUState, CP0_ErrorEPC)); tcg_gen_st_tl(t0, cpu_env, offsetof(CPUState, CP0_ErrorEPC));
rn = "ErrorEPC"; rn = "ErrorEPC";
break; break;
default: default:
...@@ -5162,7 +5162,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -5162,7 +5162,7 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
switch (sel) { switch (sel) {
case 0: case 0:
/* EJTAG support */ /* EJTAG support */
gen_mtc0_store32(cpu_T[0], offsetof(CPUState, CP0_DESAVE)); gen_mtc0_store32(t0, offsetof(CPUState, CP0_DESAVE));
rn = "DESAVE"; rn = "DESAVE";
break; break;
default: default:
...@@ -5180,9 +5180,11 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel) ...@@ -5180,9 +5180,11 @@ static void gen_dmtc0 (CPUState *env, DisasContext *ctx, int reg, int sel)
rn, reg, sel); rn, reg, sel);
} }
#endif #endif
tcg_temp_free(t0);
return; return;
die: die:
tcg_temp_free(t0);
#if defined MIPS_DEBUG_DISAS #if defined MIPS_DEBUG_DISAS
if (loglevel & CPU_LOG_TB_IN_ASM) { if (loglevel & CPU_LOG_TB_IN_ASM) {
fprintf(logfile, "dmtc0 %s (reg %d sel %d)\n", fprintf(logfile, "dmtc0 %s (reg %d sel %d)\n",
...@@ -5197,121 +5199,122 @@ static void gen_mftr(CPUState *env, DisasContext *ctx, int rt, int rd, ...@@ -5197,121 +5199,122 @@ static void gen_mftr(CPUState *env, DisasContext *ctx, int rt, int rd,
int u, int sel, int h) int u, int sel, int h)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
TCGv t0 = tcg_temp_local_new(TCG_TYPE_TL);
if ((env->CP0_VPEConf0 & (1 << CP0VPEC0_MVP)) == 0 && if ((env->CP0_VPEConf0 & (1 << CP0VPEC0_MVP)) == 0 &&
((env->CP0_TCBind[other_tc] & (0xf << CP0TCBd_CurVPE)) != ((env->CP0_TCBind[other_tc] & (0xf << CP0TCBd_CurVPE)) !=
(env->CP0_TCBind[env->current_tc] & (0xf << CP0TCBd_CurVPE)))) (env->CP0_TCBind[env->current_tc] & (0xf << CP0TCBd_CurVPE))))
tcg_gen_movi_tl(cpu_T[0], -1); tcg_gen_movi_tl(t0, -1);
else if ((env->CP0_VPEControl & (0xff << CP0VPECo_TargTC)) > else if ((env->CP0_VPEControl & (0xff << CP0VPECo_TargTC)) >
(env->mvp->CP0_MVPConf0 & (0xff << CP0MVPC0_PTC))) (env->mvp->CP0_MVPConf0 & (0xff << CP0MVPC0_PTC)))
tcg_gen_movi_tl(cpu_T[0], -1); tcg_gen_movi_tl(t0, -1);
else if (u == 0) { else if (u == 0) {
switch (rt) { switch (rt) {
case 2: case 2:
switch (sel) { switch (sel) {
case 1: case 1:
tcg_gen_helper_1_1(do_mftc0_tcstatus, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftc0_tcstatus, t0, t0);
break; break;
case 2: case 2:
tcg_gen_helper_1_1(do_mftc0_tcbind, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftc0_tcbind, t0, t0);
break; break;
case 3: case 3:
tcg_gen_helper_1_1(do_mftc0_tcrestart, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftc0_tcrestart, t0, t0);
break; break;
case 4: case 4:
tcg_gen_helper_1_1(do_mftc0_tchalt, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftc0_tchalt, t0, t0);
break; break;
case 5: case 5:
tcg_gen_helper_1_1(do_mftc0_tccontext, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftc0_tccontext, t0, t0);
break; break;
case 6: case 6:
tcg_gen_helper_1_1(do_mftc0_tcschedule, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftc0_tcschedule, t0, t0);
break; break;
case 7: case 7:
tcg_gen_helper_1_1(do_mftc0_tcschefback, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftc0_tcschefback, t0, t0);
break; break;
default: default:
gen_mfc0(env, ctx, rt, sel); gen_mfc0(env, ctx, t0, rt, sel);
break; break;
} }
break; break;
case 10: case 10:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_mftc0_entryhi, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftc0_entryhi, t0, t0);
break; break;
default: default:
gen_mfc0(env, ctx, rt, sel); gen_mfc0(env, ctx, t0, rt, sel);
break; break;
} }
case 12: case 12:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_mftc0_status, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftc0_status, t0, t0);
break; break;
default: default:
gen_mfc0(env, ctx, rt, sel); gen_mfc0(env, ctx, t0, rt, sel);
break; break;
} }
case 23: case 23:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_1_1(do_mftc0_debug, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftc0_debug, t0, t0);
break; break;
default: default:
gen_mfc0(env, ctx, rt, sel); gen_mfc0(env, ctx, t0, rt, sel);
break; break;
} }
break; break;
default: default:
gen_mfc0(env, ctx, rt, sel); gen_mfc0(env, ctx, t0, rt, sel);
} }
} else switch (sel) { } else switch (sel) {
/* GPR registers. */ /* GPR registers. */
case 0: case 0:
tcg_gen_helper_1_1i(do_mftgpr, cpu_T[0], cpu_T[0], rt); tcg_gen_helper_1_1i(do_mftgpr, t0, t0, rt);
break; break;
/* Auxiliary CPU registers */ /* Auxiliary CPU registers */
case 1: case 1:
switch (rt) { switch (rt) {
case 0: case 0:
tcg_gen_helper_1_1i(do_mftlo, cpu_T[0], cpu_T[0], 0); tcg_gen_helper_1_1i(do_mftlo, t0, t0, 0);
break; break;
case 1: case 1:
tcg_gen_helper_1_1i(do_mfthi, cpu_T[0], cpu_T[0], 0); tcg_gen_helper_1_1i(do_mfthi, t0, t0, 0);
break; break;
case 2: case 2:
tcg_gen_helper_1_1i(do_mftacx, cpu_T[0], cpu_T[0], 0); tcg_gen_helper_1_1i(do_mftacx, t0, t0, 0);
break; break;
case 4: case 4:
tcg_gen_helper_1_1i(do_mftlo, cpu_T[0], cpu_T[0], 1); tcg_gen_helper_1_1i(do_mftlo, t0, t0, 1);
break; break;
case 5: case 5:
tcg_gen_helper_1_1i(do_mfthi, cpu_T[0], cpu_T[0], 1); tcg_gen_helper_1_1i(do_mfthi, t0, t0, 1);
break; break;
case 6: case 6:
tcg_gen_helper_1_1i(do_mftacx, cpu_T[0], cpu_T[0], 1); tcg_gen_helper_1_1i(do_mftacx, t0, t0, 1);
break; break;
case 8: case 8:
tcg_gen_helper_1_1i(do_mftlo, cpu_T[0], cpu_T[0], 2); tcg_gen_helper_1_1i(do_mftlo, t0, t0, 2);
break; break;
case 9: case 9:
tcg_gen_helper_1_1i(do_mfthi, cpu_T[0], cpu_T[0], 2); tcg_gen_helper_1_1i(do_mfthi, t0, t0, 2);
break; break;
case 10: case 10:
tcg_gen_helper_1_1i(do_mftacx, cpu_T[0], cpu_T[0], 2); tcg_gen_helper_1_1i(do_mftacx, t0, t0, 2);
break; break;
case 12: case 12:
tcg_gen_helper_1_1i(do_mftlo, cpu_T[0], cpu_T[0], 3); tcg_gen_helper_1_1i(do_mftlo, t0, t0, 3);
break; break;
case 13: case 13:
tcg_gen_helper_1_1i(do_mfthi, cpu_T[0], cpu_T[0], 3); tcg_gen_helper_1_1i(do_mfthi, t0, t0, 3);
break; break;
case 14: case 14:
tcg_gen_helper_1_1i(do_mftacx, cpu_T[0], cpu_T[0], 3); tcg_gen_helper_1_1i(do_mftacx, t0, t0, 3);
break; break;
case 16: case 16:
tcg_gen_helper_1_1(do_mftdsp, cpu_T[0], cpu_T[0]); tcg_gen_helper_1_1(do_mftdsp, t0, t0);
break; break;
default: default:
goto die; goto die;
...@@ -5322,15 +5325,15 @@ static void gen_mftr(CPUState *env, DisasContext *ctx, int rt, int rd, ...@@ -5322,15 +5325,15 @@ static void gen_mftr(CPUState *env, DisasContext *ctx, int rt, int rd,
/* XXX: For now we support only a single FPU context. */ /* XXX: For now we support only a single FPU context. */
if (h == 0) { if (h == 0) {
gen_load_fpr32(fpu32_T[0], rt); gen_load_fpr32(fpu32_T[0], rt);
tcg_gen_ext_i32_tl(cpu_T[0], fpu32_T[0]); tcg_gen_ext_i32_tl(t0, fpu32_T[0]);
} else { } else {
gen_load_fpr32h(fpu32h_T[0], rt); gen_load_fpr32h(fpu32h_T[0], rt);
tcg_gen_ext_i32_tl(cpu_T[0], fpu32h_T[0]); tcg_gen_ext_i32_tl(t0, fpu32h_T[0]);
} }
break; break;
case 3: case 3:
/* XXX: For now we support only a single FPU context. */ /* XXX: For now we support only a single FPU context. */
tcg_gen_helper_1_1i(do_cfc1, cpu_T[0], cpu_T[0], rt); tcg_gen_helper_1_1i(do_cfc1, t0, t0, rt);
break; break;
/* COP2: Not implemented. */ /* COP2: Not implemented. */
case 4: case 4:
...@@ -5345,10 +5348,12 @@ static void gen_mftr(CPUState *env, DisasContext *ctx, int rt, int rd, ...@@ -5345,10 +5348,12 @@ static void gen_mftr(CPUState *env, DisasContext *ctx, int rt, int rd,
rt, u, sel, h); rt, u, sel, h);
} }
#endif #endif
gen_store_gpr(cpu_T[0], rd); gen_store_gpr(t0, rd);
tcg_temp_free(t0);
return; return;
die: die:
tcg_temp_free(t0);
#if defined MIPS_DEBUG_DISAS #if defined MIPS_DEBUG_DISAS
if (loglevel & CPU_LOG_TB_IN_ASM) { if (loglevel & CPU_LOG_TB_IN_ASM) {
fprintf(logfile, "mftr (reg %d u %d sel %d h %d)\n", fprintf(logfile, "mftr (reg %d u %d sel %d h %d)\n",
...@@ -5362,8 +5367,9 @@ static void gen_mttr(CPUState *env, DisasContext *ctx, int rd, int rt, ...@@ -5362,8 +5367,9 @@ static void gen_mttr(CPUState *env, DisasContext *ctx, int rd, int rt,
int u, int sel, int h) int u, int sel, int h)
{ {
int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC); int other_tc = env->CP0_VPEControl & (0xff << CP0VPECo_TargTC);
TCGv t0 = tcg_temp_local_new(TCG_TYPE_TL);
gen_load_gpr(cpu_T[0], rt); gen_load_gpr(t0, rt);
if ((env->CP0_VPEConf0 & (1 << CP0VPEC0_MVP)) == 0 && if ((env->CP0_VPEConf0 & (1 << CP0VPEC0_MVP)) == 0 &&
((env->CP0_TCBind[other_tc] & (0xf << CP0TCBd_CurVPE)) != ((env->CP0_TCBind[other_tc] & (0xf << CP0TCBd_CurVPE)) !=
(env->CP0_TCBind[env->current_tc] & (0xf << CP0TCBd_CurVPE)))) (env->CP0_TCBind[env->current_tc] & (0xf << CP0TCBd_CurVPE))))
...@@ -5376,108 +5382,108 @@ static void gen_mttr(CPUState *env, DisasContext *ctx, int rd, int rt, ...@@ -5376,108 +5382,108 @@ static void gen_mttr(CPUState *env, DisasContext *ctx, int rd, int rt,
case 2: case 2:
switch (sel) { switch (sel) {
case 1: case 1:
tcg_gen_helper_0_1(do_mttc0_tcstatus, cpu_T[0]); tcg_gen_helper_0_1(do_mttc0_tcstatus, t0);
break; break;
case 2: case 2:
tcg_gen_helper_0_1(do_mttc0_tcbind, cpu_T[0]); tcg_gen_helper_0_1(do_mttc0_tcbind, t0);
break; break;
case 3: case 3:
tcg_gen_helper_0_1(do_mttc0_tcrestart, cpu_T[0]); tcg_gen_helper_0_1(do_mttc0_tcrestart, t0);
break; break;
case 4: case 4:
tcg_gen_helper_0_1(do_mttc0_tchalt, cpu_T[0]); tcg_gen_helper_0_1(do_mttc0_tchalt, t0);
break; break;
case 5: case 5:
tcg_gen_helper_0_1(do_mttc0_tccontext, cpu_T[0]); tcg_gen_helper_0_1(do_mttc0_tccontext, t0);
break; break;
case 6: case 6:
tcg_gen_helper_0_1(do_mttc0_tcschedule, cpu_T[0]); tcg_gen_helper_0_1(do_mttc0_tcschedule, t0);
break; break;
case 7: case 7:
tcg_gen_helper_0_1(do_mttc0_tcschefback, cpu_T[0]); tcg_gen_helper_0_1(do_mttc0_tcschefback, t0);
break; break;
default: default:
gen_mtc0(env, ctx, rd, sel); gen_mtc0(env, ctx, t0, rd, sel);
break; break;
} }
break; break;
case 10: case 10:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mttc0_entryhi, cpu_T[0]); tcg_gen_helper_0_1(do_mttc0_entryhi, t0);
break; break;
default: default:
gen_mtc0(env, ctx, rd, sel); gen_mtc0(env, ctx, t0, rd, sel);
break; break;
} }
case 12: case 12:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mttc0_status, cpu_T[0]); tcg_gen_helper_0_1(do_mttc0_status, t0);
break; break;
default: default:
gen_mtc0(env, ctx, rd, sel); gen_mtc0(env, ctx, t0, rd, sel);
break; break;
} }
case 23: case 23:
switch (sel) { switch (sel) {
case 0: case 0:
tcg_gen_helper_0_1(do_mttc0_debug, cpu_T[0]); tcg_gen_helper_0_1(do_mttc0_debug, t0);
break; break;
default: default:
gen_mtc0(env, ctx, rd, sel); gen_mtc0(env, ctx, t0, rd, sel);
break; break;
} }
break; break;
default: default:
gen_mtc0(env, ctx, rd, sel); gen_mtc0(env, ctx, t0, rd, sel);
} }
} else switch (sel) { } else switch (sel) {
/* GPR registers. */ /* GPR registers. */
case 0: case 0:
tcg_gen_helper_0_1i(do_mttgpr, cpu_T[0], rd); tcg_gen_helper_0_1i(do_mttgpr, t0, rd);
break; break;
/* Auxiliary CPU registers */ /* Auxiliary CPU registers */
case 1: case 1:
switch (rd) { switch (rd) {
case 0: case 0:
tcg_gen_helper_0_1i(do_mttlo, cpu_T[0], 0); tcg_gen_helper_0_1i(do_mttlo, t0, 0);
break; break;
case 1: case 1:
tcg_gen_helper_0_1i(do_mtthi, cpu_T[0], 0); tcg_gen_helper_0_1i(do_mtthi, t0, 0);
break; break;
case 2: case 2:
tcg_gen_helper_0_1i(do_mttacx, cpu_T[0], 0); tcg_gen_helper_0_1i(do_mttacx, t0, 0);
break; break;
case 4: case 4:
tcg_gen_helper_0_1i(do_mttlo, cpu_T[0], 1); tcg_gen_helper_0_1i(do_mttlo, t0, 1);
break; break;
case 5: case 5:
tcg_gen_helper_0_1i(do_mtthi, cpu_T[0], 1); tcg_gen_helper_0_1i(do_mtthi, t0, 1);
break; break;
case 6: case 6:
tcg_gen_helper_0_1i(do_mttacx, cpu_T[0], 1); tcg_gen_helper_0_1i(do_mttacx, t0, 1);
break; break;
case 8: case 8:
tcg_gen_helper_0_1i(do_mttlo, cpu_T[0], 2); tcg_gen_helper_0_1i(do_mttlo, t0, 2);
break; break;
case 9: case 9:
tcg_gen_helper_0_1i(do_mtthi, cpu_T[0], 2); tcg_gen_helper_0_1i(do_mtthi, t0, 2);
break; break;
case 10: case 10:
tcg_gen_helper_0_1i(do_mttacx, cpu_T[0], 2); tcg_gen_helper_0_1i(do_mttacx, t0, 2);
break; break;
case 12: case 12:
tcg_gen_helper_0_1i(do_mttlo, cpu_T[0], 3); tcg_gen_helper_0_1i(do_mttlo, t0, 3);
break; break;
case 13: case 13:
tcg_gen_helper_0_1i(do_mtthi, cpu_T[0], 3); tcg_gen_helper_0_1i(do_mtthi, t0, 3);
break; break;
case 14: case 14:
tcg_gen_helper_0_1i(do_mttacx, cpu_T[0], 3); tcg_gen_helper_0_1i(do_mttacx, t0, 3);
break; break;
case 16: case 16:
tcg_gen_helper_0_1(do_mttdsp, cpu_T[0]); tcg_gen_helper_0_1(do_mttdsp, t0);
break; break;
default: default:
goto die; goto die;
...@@ -5487,16 +5493,16 @@ static void gen_mttr(CPUState *env, DisasContext *ctx, int rd, int rt, ...@@ -5487,16 +5493,16 @@ static void gen_mttr(CPUState *env, DisasContext *ctx, int rd, int rt,
case 2: case 2:
/* XXX: For now we support only a single FPU context. */ /* XXX: For now we support only a single FPU context. */
if (h == 0) { if (h == 0) {
tcg_gen_trunc_tl_i32(fpu32_T[0], cpu_T[0]); tcg_gen_trunc_tl_i32(fpu32_T[0], t0);
gen_store_fpr32(fpu32_T[0], rd); gen_store_fpr32(fpu32_T[0], rd);
} else { } else {
tcg_gen_trunc_tl_i32(fpu32h_T[0], cpu_T[0]); tcg_gen_trunc_tl_i32(fpu32h_T[0], t0);
gen_store_fpr32h(fpu32h_T[0], rd); gen_store_fpr32h(fpu32h_T[0], rd);
} }
break; break;
case 3: case 3:
/* XXX: For now we support only a single FPU context. */ /* XXX: For now we support only a single FPU context. */
tcg_gen_helper_0_1i(do_ctc1, cpu_T[0], rd); tcg_gen_helper_0_1i(do_ctc1, t0, rd);
break; break;
/* COP2: Not implemented. */ /* COP2: Not implemented. */
case 4: case 4:
...@@ -5511,9 +5517,11 @@ static void gen_mttr(CPUState *env, DisasContext *ctx, int rd, int rt, ...@@ -5511,9 +5517,11 @@ static void gen_mttr(CPUState *env, DisasContext *ctx, int rd, int rt,
rd, u, sel, h); rd, u, sel, h);
} }
#endif #endif
tcg_temp_free(t0);
return; return;
die: die:
tcg_temp_free(t0);
#if defined MIPS_DEBUG_DISAS #if defined MIPS_DEBUG_DISAS
if (loglevel & CPU_LOG_TB_IN_ASM) { if (loglevel & CPU_LOG_TB_IN_ASM) {
fprintf(logfile, "mttr (reg %d u %d sel %d h %d)\n", fprintf(logfile, "mttr (reg %d u %d sel %d h %d)\n",
...@@ -5533,14 +5541,24 @@ static void gen_cp0 (CPUState *env, DisasContext *ctx, uint32_t opc, int rt, int ...@@ -5533,14 +5541,24 @@ static void gen_cp0 (CPUState *env, DisasContext *ctx, uint32_t opc, int rt, int
/* Treat as NOP. */ /* Treat as NOP. */
return; return;
} }
gen_mfc0(env, ctx, rd, ctx->opcode & 0x7); {
gen_store_gpr(cpu_T[0], rt); TCGv t0 = tcg_temp_local_new(TCG_TYPE_TL);
gen_mfc0(env, ctx, t0, rd, ctx->opcode & 0x7);
gen_store_gpr(t0, rt);
tcg_temp_free(t0);
}
opn = "mfc0"; opn = "mfc0";
break; break;
case OPC_MTC0: case OPC_MTC0:
gen_load_gpr(cpu_T[0], rt); {
save_cpu_state(ctx, 1); TCGv t0 = tcg_temp_local_new(TCG_TYPE_TL);
gen_mtc0(env, ctx, rd, ctx->opcode & 0x7);
gen_load_gpr(t0, rt);
save_cpu_state(ctx, 1);
gen_mtc0(env, ctx, t0, rd, ctx->opcode & 0x7);
tcg_temp_free(t0);
}
opn = "mtc0"; opn = "mtc0";
break; break;
#if defined(TARGET_MIPS64) #if defined(TARGET_MIPS64)
...@@ -5550,15 +5568,25 @@ static void gen_cp0 (CPUState *env, DisasContext *ctx, uint32_t opc, int rt, int ...@@ -5550,15 +5568,25 @@ static void gen_cp0 (CPUState *env, DisasContext *ctx, uint32_t opc, int rt, int
/* Treat as NOP. */ /* Treat as NOP. */
return; return;
} }
gen_dmfc0(env, ctx, rd, ctx->opcode & 0x7); {
gen_store_gpr(cpu_T[0], rt); TCGv t0 = tcg_temp_local_new(TCG_TYPE_TL);
gen_dmfc0(env, ctx, t0, rd, ctx->opcode & 0x7);
gen_store_gpr(t0, rt);
tcg_temp_free(t0);
}
opn = "dmfc0"; opn = "dmfc0";
break; break;
case OPC_DMTC0: case OPC_DMTC0:
check_insn(env, ctx, ISA_MIPS3); check_insn(env, ctx, ISA_MIPS3);
gen_load_gpr(cpu_T[0], rt); {
save_cpu_state(ctx, 1); TCGv t0 = tcg_temp_local_new(TCG_TYPE_TL);
gen_dmtc0(env, ctx, rd, ctx->opcode & 0x7);
gen_load_gpr(t0, rt);
save_cpu_state(ctx, 1);
gen_dmtc0(env, ctx, t0, rd, ctx->opcode & 0x7);
tcg_temp_free(t0);
}
opn = "dmtc0"; opn = "dmtc0";
break; break;
#endif #endif
...@@ -8069,12 +8097,6 @@ static void mips_tcg_init(void) ...@@ -8069,12 +8097,6 @@ static void mips_tcg_init(void)
TCG_AREG0, TCG_AREG0,
offsetof(CPUState, fpu), offsetof(CPUState, fpu),
"current_fpu"); "current_fpu");
#if TARGET_LONG_BITS > HOST_LONG_BITS
cpu_T[0] = tcg_global_mem_new(TCG_TYPE_TL,
TCG_AREG0, offsetof(CPUState, t0), "T0");
#else
cpu_T[0] = tcg_global_reg_new(TCG_TYPE_TL, TCG_AREG1, "T0");
#endif
/* register helpers */ /* register helpers */
#undef DEF_HELPER #undef DEF_HELPER
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册