提交 df1561e2 编写于 作者: T ths

The previous patch to make breakpoints work was a performance

disaster, use a similiar hack as ARM does instead.


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@2848 c046a42c-6fe2-441c-8c8c-71466251a162
上级 6963d7af
...@@ -1002,16 +1002,6 @@ void op_jnz_T2 (void) ...@@ -1002,16 +1002,6 @@ void op_jnz_T2 (void)
RETURN(); RETURN();
} }
void op_flush_icache_range(void) {
CALL_FROM_TB2(tlb_flush_page, env, T0 + T1);
RETURN();
}
void op_flush_icache_all(void) {
CALL_FROM_TB1(tb_flush, env);
RETURN();
}
/* CP0 functions */ /* CP0 functions */
void op_mfc0_index (void) void op_mfc0_index (void)
{ {
......
...@@ -4236,7 +4236,6 @@ static void gen_cp0 (CPUState *env, DisasContext *ctx, uint32_t opc, int rt, int ...@@ -4236,7 +4236,6 @@ static void gen_cp0 (CPUState *env, DisasContext *ctx, uint32_t opc, int rt, int
break; break;
case OPC_ERET: case OPC_ERET:
opn = "eret"; opn = "eret";
save_cpu_state(ctx, 0);
gen_op_eret(); gen_op_eret();
ctx->bstate = BS_EXCP; ctx->bstate = BS_EXCP;
break; break;
...@@ -4246,7 +4245,6 @@ static void gen_cp0 (CPUState *env, DisasContext *ctx, uint32_t opc, int rt, int ...@@ -4246,7 +4245,6 @@ static void gen_cp0 (CPUState *env, DisasContext *ctx, uint32_t opc, int rt, int
MIPS_INVAL(opn); MIPS_INVAL(opn);
generate_exception(ctx, EXCP_RI); generate_exception(ctx, EXCP_RI);
} else { } else {
save_cpu_state(ctx, 0);
gen_op_deret(); gen_op_deret();
ctx->bstate = BS_EXCP; ctx->bstate = BS_EXCP;
} }
...@@ -5526,6 +5524,10 @@ static void decode_opc (CPUState *env, DisasContext *ctx) ...@@ -5526,6 +5524,10 @@ static void decode_opc (CPUState *env, DisasContext *ctx)
generate_exception(ctx, EXCP_SYSCALL); generate_exception(ctx, EXCP_SYSCALL);
break; break;
case OPC_BREAK: case OPC_BREAK:
/* XXX: Hack to work around wrong handling of self-modifying code. */
ctx->pc += 4;
save_cpu_state(ctx, 1);
ctx->pc -= 4;
generate_exception(ctx, EXCP_BREAK); generate_exception(ctx, EXCP_BREAK);
break; break;
case OPC_SPIM: case OPC_SPIM:
...@@ -5791,25 +5793,7 @@ static void decode_opc (CPUState *env, DisasContext *ctx) ...@@ -5791,25 +5793,7 @@ static void decode_opc (CPUState *env, DisasContext *ctx)
gen_ldst(ctx, op, rt, rs, imm); gen_ldst(ctx, op, rt, rs, imm);
break; break;
case OPC_CACHE: case OPC_CACHE:
/* FIXME: This works around self-modifying code, but only /* Treat as a noop */
if the guest OS handles it properly, and if there's no
such code executed in uncached space. */
if (!(rt & 0x3))
switch ((rt >> 2) & 0x7) {
case 4:
GEN_LOAD_REG_TN(T0, rs);
GEN_LOAD_IMM_TN(T1, imm);
gen_op_flush_icache_range();
break;
case 2:
case 1:
case 0:
/* Can be very inefficient. */
gen_op_flush_icache_all();
break;
default:
break;
}
break; break;
case OPC_PREF: case OPC_PREF:
/* Treat as a noop */ /* Treat as a noop */
...@@ -6079,7 +6063,8 @@ gen_intermediate_code_internal (CPUState *env, TranslationBlock *tb, ...@@ -6079,7 +6063,8 @@ gen_intermediate_code_internal (CPUState *env, TranslationBlock *tb,
switch (ctx.bstate) { switch (ctx.bstate) {
case BS_STOP: case BS_STOP:
gen_op_interrupt_restart(); gen_op_interrupt_restart();
/* Fall through. */ gen_goto_tb(&ctx, 0, ctx.pc);
break;
case BS_NONE: case BS_NONE:
save_cpu_state(ctxp, 0); save_cpu_state(ctxp, 0);
gen_goto_tb(&ctx, 0, ctx.pc); gen_goto_tb(&ctx, 0, ctx.pc);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册