diff options
author | Marcelo Tosatti <mtosatti@redhat.com> | 2010-05-04 09:45:19 -0300 |
---|---|---|
committer | Marcelo Tosatti <mtosatti@redhat.com> | 2010-05-11 14:02:21 -0300 |
commit | 273faf1b6dbdedd0fe9fc519ec73380eced667c2 (patch) | |
tree | b33c40c19ec3ea0e3a69f68a56caebba3e313067 | |
parent | 618a568da4eda5c2e41fc4e58059546806afff6b (diff) | |
download | qemu-273faf1b6dbdedd0fe9fc519ec73380eced667c2.zip qemu-273faf1b6dbdedd0fe9fc519ec73380eced667c2.tar.gz qemu-273faf1b6dbdedd0fe9fc519ec73380eced667c2.tar.bz2 |
kvm: set cpu_single_env around KVM_RUN ioctl
Zero cpu_single_env before leaving global lock protection, and
restore on return.
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
Signed-off-by: Avi Kivity <avi@redhat.com>
-rw-r--r-- | kvm-all.c | 2 |
1 files changed, 2 insertions, 0 deletions
@@ -838,9 +838,11 @@ int kvm_cpu_exec(CPUState *env) } kvm_arch_pre_run(env, run); + cpu_single_env = NULL; qemu_mutex_unlock_iothread(); ret = kvm_vcpu_ioctl(env, KVM_RUN, 0); qemu_mutex_lock_iothread(); + cpu_single_env = env; kvm_arch_post_run(env, run); if (ret == -EINTR || ret == -EAGAIN) { |