• Paul Mackerras's avatar
    KVM: PPC: Book3S HV: Don't truncate HPTE index in xlate function · 46dec40f
    Paul Mackerras authored
    This fixes a bug which causes guest virtual addresses to get translated
    to guest real addresses incorrectly when the guest is using the HPT MMU
    and has more than 256GB of RAM, or more specifically has a HPT larger
    than 2GB.  This has showed up in testing as a failure of the host to
    emulate doorbell instructions correctly on POWER9 for HPT guests with
    more than 256GB of RAM.
    
    The bug is that the HPTE index in kvmppc_mmu_book3s_64_hv_xlate()
    is stored as an int, and in forming the HPTE address, the index gets
    shifted left 4 bits as an int before being signed-extended to 64 bits.
    The simple fix is to make the variable a long int, matching the
    return type of kvmppc_hv_find_lock_hpte(), which is what calculates
    the index.
    
    Fixes: 697d3899 ("KVM: PPC: Implement MMIO emulation support for Book3S HV guests")
    Signed-off-by: default avatarPaul Mackerras <paulus@ozlabs.org>
    46dec40f
book3s_64_mmu_hv.c 53.3 KB