소스 검색

KVM: Explicity initialize cpus_hardware_enabled

Under CONFIG_MAXSMP, cpus_hardware_enabled is allocated from the heap and
not statically initialized.  This causes a crash on reboot when kvm thinks
vmx is enabled on random nonexistent cpus and accesses nonexistent percpu
lists.

Fix by explicitly clearing the variable.

Cc: stable@kernel.org
Reported-and-tested-by: Yinghai Lu <yinghai@kernel.org>
Signed-off-by: Avi Kivity <avi@redhat.com>
Avi Kivity 16 년 전
부모
커밋
a4c0364be3
1개의 변경된 파일1개의 추가작업 그리고 0개의 파일을 삭제
  1. 1 0
      virt/kvm/kvm_main.c

+ 1 - 0
virt/kvm/kvm_main.c

@@ -2305,6 +2305,7 @@ int kvm_init(void *opaque, unsigned int vcpu_size,
 		r = -ENOMEM;
 		r = -ENOMEM;
 		goto out_free_0;
 		goto out_free_0;
 	}
 	}
+	cpumask_clear(cpus_hardware_enabled);
 
 
 	r = kvm_arch_hardware_setup();
 	r = kvm_arch_hardware_setup();
 	if (r < 0)
 	if (r < 0)