]> git.baikalelectronics.ru Git - kernel.git/commit
KVM: WARN if is_unsync_root() is called on a root without a shadow page
authorSean Christopherson <seanjc@google.com>
Fri, 25 Feb 2022 18:22:48 +0000 (18:22 +0000)
committerPaolo Bonzini <pbonzini@redhat.com>
Tue, 1 Mar 2022 13:58:26 +0000 (08:58 -0500)
commit75171f8f39a603008a1a17f728d0deefbad476e0
tree800f4fac407a4bc4417b0f64036525c57df7387c
parentfcfe7071a388a8fa5c7eb0b1a21a110dd637a100
KVM: WARN if is_unsync_root() is called on a root without a shadow page

WARN and bail if is_unsync_root() is passed a root for which there is no
shadow page, i.e. is passed the physical address of one of the special
roots, which do not have an associated shadow page.  The current usage
squeaks by without bug reports because neither kvm_mmu_sync_roots() nor
kvm_mmu_sync_prev_roots() calls the helper with pae_root or pml4_root,
and 5-level AMD CPUs are not generally available, i.e. no one can coerce
KVM into calling is_unsync_root() on pml5_root.

Note, this doesn't fix the mess with 5-level nNPT, it just (hopefully)
prevents KVM from crashing.

Cc: Lai Jiangshan <jiangshanlai@gmail.com>
Signed-off-by: Sean Christopherson <seanjc@google.com>
Message-Id: <20220225182248.3812651-8-seanjc@google.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
arch/x86/kvm/mmu/mmu.c