@@ -216,7 +216,9 @@ void breakpoint_handler(CPUState *cs)
if (cs->watchpoint_hit->flags & BP_CPU) {
cs->watchpoint_hit = NULL;
if (check_hw_breakpoints(env, false)) {
- raise_exception(env, EXCP01_DB);
+ if (tcg_enabled()) {
+ raise_exception(env, EXCP01_DB);
+ }
} else {
cpu_loop_exit_noexc(cs);
}
@@ -226,7 +228,9 @@ void breakpoint_handler(CPUState *cs)
if (bp->pc == env->eip) {
if (bp->flags & BP_CPU) {
check_hw_breakpoints(env, true);
- raise_exception(env, EXCP01_DB);
+ if (tcg_enabled()) {
+ raise_exception(env, EXCP01_DB);
+ }
}
break;
}
@@ -241,7 +245,9 @@ void helper_single_step(CPUX86State *env)
check_hw_breakpoints(env, true);
env->dr[6] |= DR6_BS;
#endif
- raise_exception(env, EXCP01_DB);
+ if (tcg_enabled()) {
+ raise_exception(env, EXCP01_DB);
+ }
}
void helper_rechecking_single_step(CPUX86State *env)
@@ -282,7 +288,9 @@ void helper_set_dr(CPUX86State *env, int reg, target_ulong t0)
cpu_x86_update_dr7(env, t0);
return;
}
- raise_exception_err_ra(env, EXCP06_ILLOP, 0, GETPC());
+ if (tcg_enabled()) {
+ raise_exception_err_ra(env, EXCP06_ILLOP, 0, GETPC());
+ }
#endif
}
@@ -304,7 +312,11 @@ target_ulong helper_get_dr(CPUX86State *env, int reg)
return env->dr[7];
}
}
- raise_exception_err_ra(env, EXCP06_ILLOP, 0, GETPC());
+ if (tcg_enabled()) {
+ raise_exception_err_ra(env, EXCP06_ILLOP, 0, GETPC());
+ } else {
+ return 0;
+ }
}
/* Check if Port I/O is trapped by a breakpoint. */
@@ -329,7 +341,9 @@ void helper_bpt_io(CPUX86State *env, uint32_t port,
if (hit) {
env->dr[6] = (env->dr[6] & ~0xf) | hit;
env->eip = next_eip;
- raise_exception(env, EXCP01_DB);
+ if (tcg_enabled()) {
+ raise_exception(env, EXCP01_DB);
+ }
}
#endif
}
@@ -4040,8 +4040,10 @@ static void x86_cpu_common_class_init(ObjectClass *oc, void *data)
cc->class_by_name = x86_cpu_class_by_name;
cc->parse_features = x86_cpu_parse_featurestr;
cc->has_work = x86_cpu_has_work;
+#ifdef CONFIG_TCG
cc->do_interrupt = x86_cpu_do_interrupt;
cc->cpu_exec_interrupt = x86_cpu_exec_interrupt;
+#endif
cc->dump_state = x86_cpu_dump_state;
cc->get_crash_info = x86_cpu_get_crash_info;
cc->set_pc = x86_cpu_set_pc;
@@ -4070,7 +4072,7 @@ static void x86_cpu_common_class_init(ObjectClass *oc, void *data)
cc->gdb_core_xml_file = "i386-32bit.xml";
cc->gdb_num_core_regs = 41;
#endif
-#ifndef CONFIG_USER_ONLY
+#if defined(CONFIG_TCG) && !defined(CONFIG_USER_ONLY)
cc->debug_excp_handler = breakpoint_handler;
#endif
cc->cpu_exec_enter = x86_cpu_exec_enter;
@@ -280,8 +280,9 @@ static int cpu_post_load(void *opaque, int version_id)
for(i = 0; i < 8; i++) {
env->fptags[i] = (env->fptag_vmstate >> i) & 1;
}
- update_fp_status(env);
-
+ if (tcg_enabled()) {
+ update_fp_status(env);
+ }
cpu_breakpoint_remove_all(cs, BP_CPU);
cpu_watchpoint_remove_all(cs, BP_CPU);
{
Add the tcg_enabled() to disable tcg code in x86 target. Signed-off-by: Yang Zhong <yang.zhong@intel.com> --- target/i386/bpt_helper.c | 26 ++++++++++++++++++++------ target/i386/cpu.c | 4 +++- target/i386/machine.c | 5 +++-- 3 files changed, 26 insertions(+), 9 deletions(-)