]> xenbits.xensource.com Git - qemu-xen-4.4-testing.git/commitdiff
The previous patch to make breakpoints work was a performance
authorths <ths@c046a42c-6fe2-441c-8c8c-71466251a162>
Wed, 23 May 2007 08:18:27 +0000 (08:18 +0000)
committerths <ths@c046a42c-6fe2-441c-8c8c-71466251a162>
Wed, 23 May 2007 08:18:27 +0000 (08:18 +0000)
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

target-mips/op.c
target-mips/translate.c

index 9ba0050ce6efdf183999f7a0a4503ce98e108fe4..8f5b11c7558a402eea7f9b8950319dd31bbe5486 100644 (file)
@@ -1002,16 +1002,6 @@ void op_jnz_T2 (void)
     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 */
 void op_mfc0_index (void)
 {
index 5b497d0fdaeded895880300a855bc504598ad345..ddf560d7c60ad80e55fe2aed519c5bc4fdce0da2 100644 (file)
@@ -4236,7 +4236,6 @@ static void gen_cp0 (CPUState *env, DisasContext *ctx, uint32_t opc, int rt, int
         break;
     case OPC_ERET:
         opn = "eret";
-        save_cpu_state(ctx, 0);
         gen_op_eret();
         ctx->bstate = BS_EXCP;
         break;
@@ -4246,7 +4245,6 @@ static void gen_cp0 (CPUState *env, DisasContext *ctx, uint32_t opc, int rt, int
             MIPS_INVAL(opn);
             generate_exception(ctx, EXCP_RI);
         } else {
-            save_cpu_state(ctx, 0);
             gen_op_deret();
             ctx->bstate = BS_EXCP;
         }
@@ -5526,6 +5524,10 @@ static void decode_opc (CPUState *env, DisasContext *ctx)
             generate_exception(ctx, EXCP_SYSCALL);
             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);
             break;
         case OPC_SPIM:
@@ -5791,25 +5793,7 @@ static void decode_opc (CPUState *env, DisasContext *ctx)
          gen_ldst(ctx, op, rt, rs, imm);
          break;
     case OPC_CACHE:
-        /* FIXME: This works around self-modifying code, but only
-           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;
-            }
+        /* Treat as a noop */
         break;
     case OPC_PREF:
         /* Treat as a noop */
@@ -6079,7 +6063,8 @@ gen_intermediate_code_internal (CPUState *env, TranslationBlock *tb,
        switch (ctx.bstate) {
         case BS_STOP:
             gen_op_interrupt_restart();
-            /* Fall through. */
+            gen_goto_tb(&ctx, 0, ctx.pc);
+            break;
         case BS_NONE:
             save_cpu_state(ctxp, 0);
             gen_goto_tb(&ctx, 0, ctx.pc);