]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
KVM: MMU: Remove user access when allowing kernel access to gpte.w=0 page
authorAvi Kivity <avi@redhat.com>
Thu, 27 May 2010 11:35:58 +0000 (14:35 +0300)
committerAvi Kivity <avi@redhat.com>
Thu, 27 May 2010 12:34:44 +0000 (15:34 +0300)
If cr0.wp=0, we have to allow the guest kernel access to a page with pte.w=0.
We do that by setting spte.w=1, since the host cr0.wp must remain set so the
host can write protect pages.  Once we allow write access, we must remove
user access otherwise we mistakenly allow the user to write the page.

Reviewed-by: Xiao Guangrong <xiaoguangrong@cn.fujitsu.com>
Signed-off-by: Avi Kivity <avi@redhat.com>
arch/x86/kvm/mmu.c

index 39dd8d3120a33ea690feaba4b42d8d54d18c21d1..56f8c3c12c25618ae3c03a3c1319908b3e298d2c 100644 (file)
@@ -1894,6 +1894,9 @@ static int set_spte(struct kvm_vcpu *vcpu, u64 *sptep,
 
                spte |= PT_WRITABLE_MASK;
 
+               if (!tdp_enabled && !(pte_access & ACC_WRITE_MASK))
+                       spte &= ~PT_USER_MASK;
+
                /*
                 * Optimization: for pte sync, if spte was writable the hash
                 * lookup is unnecessary (and expensive). Write protection