diff options
-rw-r--r-- | target-alpha/translate.c | 1 | ||||
-rw-r--r-- | target-arm/translate.c | 1 | ||||
-rw-r--r-- | target-m68k/translate.c | 1 | ||||
-rw-r--r-- | target-mips/translate.c | 8 | ||||
-rw-r--r-- | target-ppc/translate.c | 1 | ||||
-rw-r--r-- | target-sh4/translate.c | 1 | ||||
-rw-r--r-- | target-sparc/translate.c | 1 |
7 files changed, 3 insertions, 11 deletions
diff --git a/target-alpha/translate.c b/target-alpha/translate.c index 77e3b4e..9ed53be 100644 --- a/target-alpha/translate.c +++ b/target-alpha/translate.c @@ -2047,7 +2047,6 @@ int gen_intermediate_code_internal (CPUState *env, TranslationBlock *tb, lj++; while (lj <= j) gen_opc_instr_start[lj++] = 0; - tb->size = 0; } else { tb->size = ctx.pc - pc_start; } diff --git a/target-arm/translate.c b/target-arm/translate.c index 799aef2..590959c 100644 --- a/target-arm/translate.c +++ b/target-arm/translate.c @@ -3656,7 +3656,6 @@ static inline int gen_intermediate_code_internal(CPUState *env, lj++; while (lj <= j) gen_opc_instr_start[lj++] = 0; - tb->size = 0; } else { tb->size = dc->pc - pc_start; } diff --git a/target-m68k/translate.c b/target-m68k/translate.c index 9fa4602..8adc9c3 100644 --- a/target-m68k/translate.c +++ b/target-m68k/translate.c @@ -3260,7 +3260,6 @@ gen_intermediate_code_internal(CPUState *env, TranslationBlock *tb, lj++; while (lj <= j) gen_opc_instr_start[lj++] = 0; - tb->size = 0; } else { tb->size = dc->pc - pc_start; } diff --git a/target-mips/translate.c b/target-mips/translate.c index c87f2c9..d7bb20a 100644 --- a/target-mips/translate.c +++ b/target-mips/translate.c @@ -5882,10 +5882,6 @@ 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: @@ -6433,6 +6429,9 @@ gen_intermediate_code_internal (CPUState *env, TranslationBlock *tb, save_cpu_state(&ctx, 1); ctx.bstate = BS_BRANCH; gen_op_debug(); + /* Include the breakpoint location or the tb won't + * be flushed when it must be. */ + ctx.pc += 4; goto done_generating; } } @@ -6493,7 +6492,6 @@ done_generating: lj++; while (lj <= j) gen_opc_instr_start[lj++] = 0; - tb->size = 0; } else { tb->size = ctx.pc - pc_start; } diff --git a/target-ppc/translate.c b/target-ppc/translate.c index e5064c0..40a1176 100644 --- a/target-ppc/translate.c +++ b/target-ppc/translate.c @@ -5878,7 +5878,6 @@ static inline int gen_intermediate_code_internal (CPUState *env, lj++; while (lj <= j) gen_opc_instr_start[lj++] = 0; - tb->size = 0; } else { tb->size = ctx.nip - pc_start; } diff --git a/target-sh4/translate.c b/target-sh4/translate.c index 67ef839..5842c29 100644 --- a/target-sh4/translate.c +++ b/target-sh4/translate.c @@ -1242,7 +1242,6 @@ gen_intermediate_code_internal(CPUState * env, TranslationBlock * tb, ii++; while (ii <= i) gen_opc_instr_start[ii++] = 0; - tb->size = 0; } else { tb->size = ctx.pc - pc_start; } diff --git a/target-sparc/translate.c b/target-sparc/translate.c index 2b42ffd..54b861a 100644 --- a/target-sparc/translate.c +++ b/target-sparc/translate.c @@ -3365,7 +3365,6 @@ static inline int gen_intermediate_code_internal(TranslationBlock * tb, lj++; while (lj <= j) gen_opc_instr_start[lj++] = 0; - tb->size = 0; #if 0 if (loglevel > 0) { page_dump(logfile); |