mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-07 14:32:23 +00:00
KVM: Remove on_each_cpu(hardware_disable_nolock) in kvm_exit()
Drop the superfluous invocation of hardware_disable_nolock() during kvm_exit(), as it's nothing more than a glorified nop. KVM automatically disables hardware on all CPUs when the last VM is destroyed, and kvm_exit() cannot be called until the last VM goes away as the calling module is pinned by an elevated refcount of the fops associated with /dev/kvm. This holds true even on x86, where the caller of kvm_exit() is not kvm.ko, but is instead a dependent module, kvm_amd.ko or kvm_intel.ko, as kvm_chardev_ops.owner is set to the module that calls kvm_init(), not hardcoded to the base kvm.ko module. Signed-off-by: Isaku Yamahata <isaku.yamahata@intel.com> [sean: rework changelog] Signed-off-by: Sean Christopherson <seanjc@google.com> Message-Id: <20221130230934.1014142-46-seanjc@google.com> Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
This commit is contained in:
parent
0bf50497f0
commit
667a83bf6a
@ -6050,7 +6050,6 @@ void kvm_exit(void)
|
|||||||
unregister_syscore_ops(&kvm_syscore_ops);
|
unregister_syscore_ops(&kvm_syscore_ops);
|
||||||
unregister_reboot_notifier(&kvm_reboot_notifier);
|
unregister_reboot_notifier(&kvm_reboot_notifier);
|
||||||
cpuhp_remove_state_nocalls(CPUHP_AP_KVM_ONLINE);
|
cpuhp_remove_state_nocalls(CPUHP_AP_KVM_ONLINE);
|
||||||
on_each_cpu(hardware_disable_nolock, NULL, 1);
|
|
||||||
kvm_irqfd_exit();
|
kvm_irqfd_exit();
|
||||||
free_cpumask_var(cpus_hardware_enabled);
|
free_cpumask_var(cpus_hardware_enabled);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user