aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/kvm/kvm_main.c
diff options
context:
space:
mode:
authorAvi Kivity <avi@qumranet.com>2007-01-05 19:36:57 -0500
committerLinus Torvalds <torvalds@woody.osdl.org>2007-01-06 02:55:28 -0500
commit86a2b42e81b8236d9454f5c2d7113a82ed25c735 (patch)
treee3777ce73f78f6ec92c3830f71784ba973814c67 /drivers/kvm/kvm_main.c
parente52de1b8cf85aa2ccaaa253b4397c6d6cc0d4897 (diff)
[PATCH] KVM: Initialize vcpu->kvm a little earlier
Fixes oops on early close of /dev/kvm. Signed-off-by: Avi Kivity <avi@qumranet.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'drivers/kvm/kvm_main.c')
-rw-r--r--drivers/kvm/kvm_main.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/kvm/kvm_main.c b/drivers/kvm/kvm_main.c
index 6e15aef6c34f..a8b425284bd7 100644
--- a/drivers/kvm/kvm_main.c
+++ b/drivers/kvm/kvm_main.c
@@ -230,6 +230,7 @@ static int kvm_dev_open(struct inode *inode, struct file *filp)
230 struct kvm_vcpu *vcpu = &kvm->vcpus[i]; 230 struct kvm_vcpu *vcpu = &kvm->vcpus[i];
231 231
232 mutex_init(&vcpu->mutex); 232 mutex_init(&vcpu->mutex);
233 vcpu->kvm = kvm;
233 vcpu->mmu.root_hpa = INVALID_PAGE; 234 vcpu->mmu.root_hpa = INVALID_PAGE;
234 INIT_LIST_HEAD(&vcpu->free_pages); 235 INIT_LIST_HEAD(&vcpu->free_pages);
235 } 236 }
@@ -530,7 +531,6 @@ static int kvm_dev_ioctl_create_vcpu(struct kvm *kvm, int n)
530 vcpu->guest_fx_image = vcpu->host_fx_image + FX_IMAGE_SIZE; 531 vcpu->guest_fx_image = vcpu->host_fx_image + FX_IMAGE_SIZE;
531 532
532 vcpu->cpu = -1; /* First load will set up TR */ 533 vcpu->cpu = -1; /* First load will set up TR */
533 vcpu->kvm = kvm;
534 r = kvm_arch_ops->vcpu_create(vcpu); 534 r = kvm_arch_ops->vcpu_create(vcpu);
535 if (r < 0) 535 if (r < 0)
536 goto out_free_vcpus; 536 goto out_free_vcpus;