• Sean Christopherson's avatar
    KVM: WARN if is_unsync_root() is called on a root without a shadow page · 5d6a3221
    Sean Christopherson authored
    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: default avatarSean Christopherson <seanjc@google.com>
    Message-Id: <20220225182248.3812651-8-seanjc@google.com>
    Signed-off-by: default avatarPaolo Bonzini <pbonzini@redhat.com>
    5d6a3221
mmu.c 172 KB