提交 6164e6d6 编写于 作者: M Marcelo Tosatti

kvm_init_vcpu requires global lock held

Since it accesses data protected by the lock.
Signed-off-by: NAvi Kivity <avi@redhat.com>
上级 20420430
...@@ -401,6 +401,7 @@ static void *kvm_cpu_thread_fn(void *arg) ...@@ -401,6 +401,7 @@ static void *kvm_cpu_thread_fn(void *arg)
{ {
CPUState *env = arg; CPUState *env = arg;
qemu_mutex_lock(&qemu_global_mutex);
qemu_thread_self(env->thread); qemu_thread_self(env->thread);
if (kvm_enabled()) if (kvm_enabled())
kvm_init_vcpu(env); kvm_init_vcpu(env);
...@@ -408,7 +409,6 @@ static void *kvm_cpu_thread_fn(void *arg) ...@@ -408,7 +409,6 @@ static void *kvm_cpu_thread_fn(void *arg)
kvm_block_io_signals(env); kvm_block_io_signals(env);
/* signal CPU creation */ /* signal CPU creation */
qemu_mutex_lock(&qemu_global_mutex);
env->created = 1; env->created = 1;
qemu_cond_signal(&qemu_cpu_cond); qemu_cond_signal(&qemu_cpu_cond);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册