diff options
author | Zachary Amsden <zamsden@redhat.com> | 2009-09-29 11:38:37 -1000 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2009-12-03 09:32:13 +0200 |
commit | 3230bb4707278dba25e24cd0a11ea7b2337678ee (patch) | |
tree | 9548dc371d338b1eb7ee93ef077c70a050cd303f /arch/x86/kvm/svm.c | |
parent | e6732a5af9dfcc87078706a1598df0efe5010f73 (diff) | |
download | kernel_samsung_smdk4412-3230bb4707278dba25e24cd0a11ea7b2337678ee.tar.gz kernel_samsung_smdk4412-3230bb4707278dba25e24cd0a11ea7b2337678ee.tar.bz2 kernel_samsung_smdk4412-3230bb4707278dba25e24cd0a11ea7b2337678ee.zip |
KVM: Fix hotplug of CPUs
Both VMX and SVM require per-cpu memory allocation, which is done at module
init time, for only online cpus.
Backend was not allocating enough structure for all possible CPUs, so
new CPUs coming online could not be hardware enabled.
Signed-off-by: Zachary Amsden <zamsden@redhat.com>
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
Diffstat (limited to 'arch/x86/kvm/svm.c')
-rw-r--r-- | arch/x86/kvm/svm.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/arch/x86/kvm/svm.c b/arch/x86/kvm/svm.c index d1036ce8917..02a4269be64 100644 --- a/arch/x86/kvm/svm.c +++ b/arch/x86/kvm/svm.c @@ -482,7 +482,7 @@ static __init int svm_hardware_setup(void) kvm_enable_efer_bits(EFER_SVME); } - for_each_online_cpu(cpu) { + for_each_possible_cpu(cpu) { r = svm_cpu_init(cpu); if (r) goto err; @@ -516,7 +516,7 @@ static __exit void svm_hardware_unsetup(void) { int cpu; - for_each_online_cpu(cpu) + for_each_possible_cpu(cpu) svm_cpu_uninit(cpu); __free_pages(pfn_to_page(iopm_base >> PAGE_SHIFT), IOPM_ALLOC_ORDER); |