提交 a896d03b 编写于 作者: P Peter Maydell 提交者: Blue Swirl

gdbstub: Synchronize CPU state unconditionally in gdb_set_cpu_pc

Synchronize the CPU state via cpu_sychronize_state() unconditionally
in gdb_set_cpu_pc() rather than only in some of the target ifdef
ladder cases.

We can divide the CPUs into three categories:
 * non-KVM targets: no change of behaviour since we will use the
   kvm-stub.c no-op function.
 * i386 and s390: no change of behaviour since they were already
   calling this function
 * PPC (in KVM mode): this fixes an error: failing to synchronise
   was accidental and probably a bug.

This also paves the way for other targets (specifically ARM) which
can add KVM support in future without having to add another target
specific change to this bit of code.
Signed-off-by: NPeter Maydell <peter.maydell@linaro.org>
Signed-off-by: NBlue Swirl <blauwirbel@gmail.com>
上级 0eb4fc81
...@@ -1903,8 +1903,8 @@ static void gdb_breakpoint_remove_all(void) ...@@ -1903,8 +1903,8 @@ static void gdb_breakpoint_remove_all(void)
static void gdb_set_cpu_pc(GDBState *s, target_ulong pc) static void gdb_set_cpu_pc(GDBState *s, target_ulong pc)
{ {
#if defined(TARGET_I386)
cpu_synchronize_state(s->c_cpu); cpu_synchronize_state(s->c_cpu);
#if defined(TARGET_I386)
s->c_cpu->eip = pc; s->c_cpu->eip = pc;
#elif defined (TARGET_PPC) #elif defined (TARGET_PPC)
s->c_cpu->nip = pc; s->c_cpu->nip = pc;
...@@ -1929,7 +1929,6 @@ static void gdb_set_cpu_pc(GDBState *s, target_ulong pc) ...@@ -1929,7 +1929,6 @@ static void gdb_set_cpu_pc(GDBState *s, target_ulong pc)
#elif defined (TARGET_ALPHA) #elif defined (TARGET_ALPHA)
s->c_cpu->pc = pc; s->c_cpu->pc = pc;
#elif defined (TARGET_S390X) #elif defined (TARGET_S390X)
cpu_synchronize_state(s->c_cpu);
s->c_cpu->psw.addr = pc; s->c_cpu->psw.addr = pc;
#elif defined (TARGET_LM32) #elif defined (TARGET_LM32)
s->c_cpu->pc = pc; s->c_cpu->pc = pc;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册