From: Andreas Färber Date: Tue, 9 Jul 2013 18:50:52 +0000 (+0200) Subject: Revert "gdbstub: Simplify find_cpu()" X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=aa48dd9319dcee78ec17f4d516fb7bfc62b1a4d2;p=qmiga%2Fqemu.git Revert "gdbstub: Simplify find_cpu()" This reverts commit c52a6b67c1d7c6fc9fb2e3ba988d7b978e1487d3, which replaced cpu_index() with cpu_index field, leading to deviation from thread ID for NTPL and off-by-one otherwise. Reported-by: Max Filippov Signed-off-by: Andreas Färber --- diff --git a/gdbstub.c b/gdbstub.c index 3101a43404..9ae657620e 100644 --- a/gdbstub.c +++ b/gdbstub.c @@ -2071,13 +2071,17 @@ static void gdb_set_cpu_pc(GDBState *s, target_ulong pc) static CPUArchState *find_cpu(uint32_t thread_id) { + CPUArchState *env; CPUState *cpu; - cpu = qemu_get_cpu(thread_id); - if (cpu == NULL) { - return NULL; + for (env = first_cpu; env != NULL; env = env->next_cpu) { + cpu = ENV_GET_CPU(env); + if (cpu_index(cpu) == thread_id) { + return env; + } } - return cpu->env_ptr; + + return NULL; } static int gdb_handle_packet(GDBState *s, const char *line_buf)