KVM: ppc: fix userspace mapping invalidation on context switch
authorHollis Blanchard <hollisb@us.ibm.com>
Mon, 10 Nov 2008 20:57:36 +0000 (14:57 -0600)
committerAvi Kivity <avi@redhat.com>
Wed, 31 Dec 2008 14:52:26 +0000 (16:52 +0200)
commitfe4e771d5c37f0949047faf95d16a512b21406bf
tree518b4ff17a8e1e62b747ce1912c08b62883d2855
parentdf9b856c454e331bc394c80903fcdea19cae2a33
KVM: ppc: fix userspace mapping invalidation on context switch

We used to defer invalidating userspace TLB entries until jumping out of the
kernel. This was causing MMU weirdness most easily triggered by using a pipe in
the guest, e.g. "dmesg | tail". I believe the problem was that after the guest
kernel changed the PID (part of context switch), the old process's mappings
were still present, and so copy_to_user() on the "return to new process" path
ended up using stale mappings.

Testing with large pages (64K) exposed the problem, probably because with 4K
pages, pressure on the TLB faulted all process A's mappings out before the
guest kernel could insert any for process B.

Signed-off-by: Hollis Blanchard <hollisb@us.ibm.com>
Signed-off-by: Avi Kivity <avi@redhat.com>
arch/powerpc/include/asm/kvm_44x.h
arch/powerpc/kvm/44x_emulate.c
arch/powerpc/kvm/44x_tlb.c