KVM: PPC: Book3S HV: Synthesize segment fault if SLB lookup fails
authorPaul Mackerras <paulus@samba.org>
Tue, 27 Oct 2015 05:10:20 +0000 (16:10 +1100)
committerPaul Mackerras <paulus@samba.org>
Fri, 6 Nov 2015 04:40:42 +0000 (15:40 +1100)
commitcf29b21595b91eecce6ca69b0f92d60bca076ef0
tree503357c2f4b036259c6061923170047dfbdcf2f5
parenta3eaa8649e4c6a6afdafaa04b9114fb230617bb1
KVM: PPC: Book3S HV: Synthesize segment fault if SLB lookup fails

When handling a hypervisor data or instruction storage interrupt (HDSI
or HISI), we look up the SLB entry for the address being accessed in
order to translate the effective address to a virtual address which can
be looked up in the guest HPT.  This lookup can occasionally fail due
to the guest replacing an SLB entry without invalidating the evicted
SLB entry.  In this situation an ERAT (effective to real address
translation cache) entry can persist and be used by the hardware even
though there is no longer a corresponding SLB entry.

Previously we would just deliver a data or instruction storage interrupt
(DSI or ISI) to the guest in this case.  However, this is not correct
and has been observed to cause guests to crash, typically with a
data storage protection interrupt on a store to the vmemmap area.

Instead, what we do now is to synthesize a data or instruction segment
interrupt.  That should cause the guest to reload an appropriate entry
into the SLB and retry the faulting instruction.  If it still faults,
we should find an appropriate SLB entry next time and be able to handle
the fault.

Tested-by: Thomas Huth <thuth@redhat.com>
Reviewed-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Paul Mackerras <paulus@samba.org>
arch/powerpc/kvm/book3s_hv_rmhandlers.S