gdb stub breakpoints support git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@332 c046a42c-6fe2-441c-8c8c-71466251a162
diff --git a/exec.c b/exec.c index e7f5081..fc0a0cf 100644 --- a/exec.c +++ b/exec.c
@@ -617,6 +617,48 @@ tb_reset_jump_recursive2(tb, 1); } +/* add a breakpoint */ +int cpu_breakpoint_insert(CPUState *env, uint32_t pc) +{ +#if defined(TARGET_I386) + int i; + + for(i = 0; i < env->nb_breakpoints; i++) { + if (env->breakpoints[i] == pc) + return 0; + } + + if (env->nb_breakpoints >= MAX_BREAKPOINTS) + return -1; + env->breakpoints[env->nb_breakpoints++] = pc; + tb_invalidate_page(pc); + return 0; +#else + return -1; +#endif +} + +/* remove a breakpoint */ +int cpu_breakpoint_remove(CPUState *env, uint32_t pc) +{ +#if defined(TARGET_I386) + int i; + for(i = 0; i < env->nb_breakpoints; i++) { + if (env->breakpoints[i] == pc) + goto found; + } + return -1; + found: + memmove(&env->breakpoints[i], &env->breakpoints[i + 1], + (env->nb_breakpoints - (i + 1)) * sizeof(env->breakpoints[0])); + env->nb_breakpoints--; + tb_invalidate_page(pc); + return 0; +#else + return -1; +#endif +} + /* mask must never be zero */ void cpu_interrupt(CPUState *env, int mask) {