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)
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>

No differences found