|
@@ -568,6 +568,22 @@ void cpu_thread_signal_destroyed(CPUState *cpu)
|
|
qemu_cond_signal(&qemu_cpu_cond);
|
|
qemu_cond_signal(&qemu_cpu_cond);
|
|
}
|
|
}
|
|
|
|
|
|
|
|
+void cpu_pause(CPUState *cpu)
|
|
|
|
+{
|
|
|
|
+ if (qemu_cpu_is_self(cpu)) {
|
|
|
|
+ qemu_cpu_stop(cpu, true);
|
|
|
|
+ } else {
|
|
|
|
+ cpu->stop = true;
|
|
|
|
+ qemu_cpu_kick(cpu);
|
|
|
|
+ }
|
|
|
|
+}
|
|
|
|
+
|
|
|
|
+void cpu_resume(CPUState *cpu)
|
|
|
|
+{
|
|
|
|
+ cpu->stop = false;
|
|
|
|
+ cpu->stopped = false;
|
|
|
|
+ qemu_cpu_kick(cpu);
|
|
|
|
+}
|
|
|
|
|
|
static bool all_vcpus_paused(void)
|
|
static bool all_vcpus_paused(void)
|
|
{
|
|
{
|
|
@@ -588,12 +604,7 @@ void pause_all_vcpus(void)
|
|
|
|
|
|
qemu_clock_enable(QEMU_CLOCK_VIRTUAL, false);
|
|
qemu_clock_enable(QEMU_CLOCK_VIRTUAL, false);
|
|
CPU_FOREACH(cpu) {
|
|
CPU_FOREACH(cpu) {
|
|
- if (qemu_cpu_is_self(cpu)) {
|
|
|
|
- qemu_cpu_stop(cpu, true);
|
|
|
|
- } else {
|
|
|
|
- cpu->stop = true;
|
|
|
|
- qemu_cpu_kick(cpu);
|
|
|
|
- }
|
|
|
|
|
|
+ cpu_pause(cpu);
|
|
}
|
|
}
|
|
|
|
|
|
/* We need to drop the replay_lock so any vCPU threads woken up
|
|
/* We need to drop the replay_lock so any vCPU threads woken up
|
|
@@ -613,13 +624,6 @@ void pause_all_vcpus(void)
|
|
bql_lock();
|
|
bql_lock();
|
|
}
|
|
}
|
|
|
|
|
|
-void cpu_resume(CPUState *cpu)
|
|
|
|
-{
|
|
|
|
- cpu->stop = false;
|
|
|
|
- cpu->stopped = false;
|
|
|
|
- qemu_cpu_kick(cpu);
|
|
|
|
-}
|
|
|
|
-
|
|
|
|
void resume_all_vcpus(void)
|
|
void resume_all_vcpus(void)
|
|
{
|
|
{
|
|
CPUState *cpu;
|
|
CPUState *cpu;
|