KVM: MMU: Fix host memory corruption on i386 with >= 4GB ram
authorAvi Kivity <avi@qumranet.com>
Fri, 9 Mar 2007 11:04:31 +0000 (13:04 +0200)
committerAvi Kivity <avi@qumranet.com>
Sun, 18 Mar 2007 08:49:09 +0000 (10:49 +0200)
PAGE_MASK is an unsigned long, so using it to mask physical addresses on
i386 (which are 64-bit wide) leads to truncation.  This can result in
page->private of unrelated memory pages being modified, with disasterous
results.

Fix by not using PAGE_MASK for physical addresses; instead calculate
the correct value directly from PAGE_SIZE.  Also fix a similar BUG_ON().

Acked-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Avi Kivity <avi@qumranet.com>
drivers/kvm/mmu.c

Simple merge