KVM: nSVM: Use KVM-governed feature framework to track "vNMI enabled"
authorSean Christopherson <seanjc@google.com>
Tue, 15 Aug 2023 20:36:52 +0000 (13:36 -0700)
committerSean Christopherson <seanjc@google.com>
Thu, 17 Aug 2023 18:43:31 +0000 (11:43 -0700)
commitee785c870d6f80380be6549772137a41c527d0ba
treee413f11590453fb323f8dcc176e4e1477121d9ba
parentb89456aee78d22b20c6c83c4d75af7985ae5be8d
KVM: nSVM: Use KVM-governed feature framework to track "vNMI enabled"

Track "virtual NMI exposed to L1" via a governed feature flag instead of
using a dedicated bit/flag in vcpu_svm.

Note, checking KVM's capabilities instead of the "vnmi" param means that
the code isn't strictly equivalent, as vnmi_enabled could have been set
if nested=false where as that the governed feature cannot.  But that's a
glorified nop as the feature/flag is consumed only by paths that are
gated by nSVM being enabled.

Link: https://lore.kernel.org/r/20230815203653.519297-15-seanjc@google.com
Signed-off-by: Sean Christopherson <seanjc@google.com>
arch/x86/kvm/governed_features.h
arch/x86/kvm/svm/svm.c
arch/x86/kvm/svm/svm.h