]> asedeno.scripts.mit.edu Git - linux.git/commit
x86: Add "nopv" parameter to disable PV extensions
authorZhenzhong Duan <zhenzhong.duan@oracle.com>
Thu, 11 Jul 2019 12:02:09 +0000 (20:02 +0800)
committerJuergen Gross <jgross@suse.com>
Wed, 17 Jul 2019 06:09:58 +0000 (08:09 +0200)
commit30978346372e5c43a652cfbd4533c6bd5427c33b
tree0fb7e6a976d391af1469f7c4e210bef06e7ef5cb
parent1b37683cda0217305837fd1b79e7c57104d4f983
x86: Add "nopv" parameter to disable PV extensions

In virtualization environment, PV extensions (drivers, interrupts,
timers, etc) are enabled in the majority of use cases which is the
best option.

However, in some cases (kexec not fully working, benchmarking)
we want to disable PV extensions. We have "xen_nopv" for that purpose
but only for XEN. For a consistent admin experience a common command
line parameter "nopv" set across all PV guest implementations is a
better choice.

There are guest types which just won't work without PV extensions,
like Xen PV, Xen PVH and jailhouse. add a "ignore_nopv" member to
struct hypervisor_x86 set to true for those guest types and call
the detect functions only if nopv is false or ignore_nopv is true.

Suggested-by: Juergen Gross <jgross@suse.com>
Signed-off-by: Zhenzhong Duan <zhenzhong.duan@oracle.com>
Reviewed-by: Juergen Gross <jgross@suse.com>
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: Borislav Petkov <bp@alien8.de>
Cc: Jan Kiszka <jan.kiszka@siemens.com>
Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com>
Cc: Stefano Stabellini <sstabellini@kernel.org>
Signed-off-by: Juergen Gross <jgross@suse.com>
Documentation/admin-guide/kernel-parameters.txt
arch/x86/include/asm/hypervisor.h
arch/x86/kernel/cpu/hypervisor.c
arch/x86/kernel/jailhouse.c
arch/x86/xen/enlighten_pv.c