提交 b29a0341 编写于 作者: T ths

EBase is limited to KSEG0/KSEG1 even on 64bit CPUs.


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2351 c046a42c-6fe2-441c-8c8c-71466251a162
上级 4de9b249
...@@ -162,7 +162,7 @@ struct CPUMIPSState { ...@@ -162,7 +162,7 @@ struct CPUMIPSState {
#define CP0Ca_EC 2 #define CP0Ca_EC 2
target_ulong CP0_EPC; target_ulong CP0_EPC;
int32_t CP0_PRid; int32_t CP0_PRid;
target_ulong CP0_EBase; int32_t CP0_EBase;
int32_t CP0_Config0; int32_t CP0_Config0;
#define CP0C0_M 31 #define CP0C0_M 31
#define CP0C0_K23 28 #define CP0C0_K23 28
......
...@@ -1158,7 +1158,7 @@ void op_mfc0_prid (void) ...@@ -1158,7 +1158,7 @@ void op_mfc0_prid (void)
void op_mfc0_ebase (void) void op_mfc0_ebase (void)
{ {
T0 = (int32_t)env->CP0_EBase; T0 = env->CP0_EBase;
RETURN(); RETURN();
} }
...@@ -1423,7 +1423,7 @@ void op_mtc0_ebase (void) ...@@ -1423,7 +1423,7 @@ void op_mtc0_ebase (void)
{ {
/* vectored interrupts not implemented */ /* vectored interrupts not implemented */
/* Multi-CPU not implemented */ /* Multi-CPU not implemented */
env->CP0_EBase = (int32_t)0x80000000 | (T0 & 0x3FFFF000); env->CP0_EBase = 0x80000000 | (T0 & 0x3FFFF000);
RETURN(); RETURN();
} }
...@@ -1563,12 +1563,6 @@ void op_dmfc0_epc (void) ...@@ -1563,12 +1563,6 @@ void op_dmfc0_epc (void)
RETURN(); RETURN();
} }
void op_dmfc0_ebase (void)
{
T0 = env->CP0_EBase;
RETURN();
}
void op_dmfc0_lladdr (void) void op_dmfc0_lladdr (void)
{ {
T0 = env->CP0_LLAddr >> 4; T0 = env->CP0_LLAddr >> 4;
...@@ -1627,15 +1621,6 @@ void op_dmtc0_epc (void) ...@@ -1627,15 +1621,6 @@ void op_dmtc0_epc (void)
RETURN(); RETURN();
} }
void op_dmtc0_ebase (void)
{
/* vectored interrupts not implemented */
/* Multi-CPU not implemented */
/* XXX: 64bit addressing broken */
env->CP0_EBase = (int32_t)0x80000000 | (T0 & 0x3FFFF000);
RETURN();
}
void op_dmtc0_watchlo0 (void) void op_dmtc0_watchlo0 (void)
{ {
env->CP0_WatchLo = T0; env->CP0_WatchLo = T0;
......
...@@ -3099,7 +3099,7 @@ static void gen_dmfc0 (DisasContext *ctx, int reg, int sel) ...@@ -3099,7 +3099,7 @@ static void gen_dmfc0 (DisasContext *ctx, int reg, int sel)
rn = "PRid"; rn = "PRid";
break; break;
case 1: case 1:
gen_op_dmfc0_ebase(); gen_op_mfc0_ebase();
rn = "EBase"; rn = "EBase";
break; break;
default: default:
...@@ -3683,7 +3683,7 @@ static void gen_dmtc0 (DisasContext *ctx, int reg, int sel) ...@@ -3683,7 +3683,7 @@ static void gen_dmtc0 (DisasContext *ctx, int reg, int sel)
rn = "PRid"; rn = "PRid";
break; break;
case 1: case 1:
gen_op_dmtc0_ebase(); gen_op_mtc0_ebase();
rn = "EBase"; rn = "EBase";
break; break;
default: default:
...@@ -5305,7 +5305,7 @@ void cpu_reset (CPUMIPSState *env) ...@@ -5305,7 +5305,7 @@ void cpu_reset (CPUMIPSState *env)
#endif #endif
env->CP0_Wired = 0; env->CP0_Wired = 0;
/* SMP not implemented */ /* SMP not implemented */
env->CP0_EBase = (int32_t)0x80000000; env->CP0_EBase = 0x80000000;
env->CP0_Config0 = MIPS_CONFIG0; env->CP0_Config0 = MIPS_CONFIG0;
env->CP0_Config1 = MIPS_CONFIG1; env->CP0_Config1 = MIPS_CONFIG1;
env->CP0_Config2 = MIPS_CONFIG2; env->CP0_Config2 = MIPS_CONFIG2;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册