• James Hogan's avatar
    KVM: MIPS/T&E: Don't treat code fetch faults as MMIO · a1ecc54d
    James Hogan authored
    In order to make use of the CP0_BadInstr & CP0_BadInstrP registers we
    need to be a bit more careful not to treat code fetch faults as MMIO,
    lest we hit an UNPREDICTABLE register value when we try to emulate the
    MMIO load instruction but there was no valid instruction word available
    to the hardware.
    
    Add a kvm_is_ifetch_fault() helper to try to figure out whether a load
    fault was due to a code fetch, and prevent MMIO instruction emulation in
    that case.
    Signed-off-by: default avatarJames Hogan <james.hogan@imgtec.com>
    Cc: Paolo Bonzini <pbonzini@redhat.com>
    Cc: "Radim Krčmář" <rkrcmar@redhat.com>
    Cc: Ralf Baechle <ralf@linux-mips.org>
    Cc: linux-mips@linux-mips.org
    Cc: kvm@vger.kernel.org
    a1ecc54d
trap_emul.c 24.2 KB