From c37cc7b072fa4ca8d8d21ac31d26baff5f47f9f9 Mon Sep 17 00:00:00 2001 From: Marcelo Tosatti Date: Tue, 9 Feb 2010 12:49:04 -0200 Subject: iothread: fix vcpu stop with smp tcg Round robin vcpus in tcg_cpu_next even if the vm stopped. This allows all cpus to enter stopped state. Signed-off-by: Marcelo Tosatti Signed-off-by: Anthony Liguori --- vl.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/vl.c b/vl.c index 29f2189..98918ac 100644 --- a/vl.c +++ b/vl.c @@ -3876,14 +3876,15 @@ static void tcg_cpu_exec(void) for (; next_cpu != NULL; next_cpu = next_cpu->next_cpu) { CPUState *env = cur_cpu = next_cpu; - if (!vm_running) - break; if (timer_alarm_pending) { timer_alarm_pending = 0; break; } if (cpu_can_run(env)) ret = qemu_cpu_exec(env); + else if (env->stop) + break; + if (ret == EXCP_DEBUG) { gdb_set_stop_cpu(env); debug_requested = 1; -- cgit v1.1