From mboxrd@z Thu Jan 1 00:00:00 1970 From: Xiao Guangrong Subject: Re: [PATCH v2 10/16] KVM: MMU: fask check whether page is writable Date: Mon, 16 Apr 2012 11:38:51 +0800 Message-ID: <4F8B944B.7070807@linux.vnet.ibm.com> References: <4F87FA69.5060106@linux.vnet.ibm.com> <4F87FC82.2050302@linux.vnet.ibm.com> <20120414120153.76c3afca3726c14d10581a6c@gmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit Cc: Avi Kivity , Marcelo Tosatti , LKML , KVM To: Takuya Yoshikawa Return-path: Received: from e23smtp03.au.ibm.com ([202.81.31.145]:37328 "EHLO e23smtp03.au.ibm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751680Ab2DPDje (ORCPT ); Sun, 15 Apr 2012 23:39:34 -0400 Received: from /spool/local by e23smtp03.au.ibm.com with IBM ESMTP SMTP Gateway: Authorized Use Only! Violators will be prosecuted for from ; Mon, 16 Apr 2012 03:29:55 +1000 In-Reply-To: <20120414120153.76c3afca3726c14d10581a6c@gmail.com> Sender: kvm-owner@vger.kernel.org List-ID: On 04/14/2012 11:01 AM, Takuya Yoshikawa wrote: > On Fri, 13 Apr 2012 18:14:26 +0800 > Xiao Guangrong wrote: > >> Using bit 1 (PTE_LIST_WP_BIT) in rmap store the write-protect status >> to avoid unnecessary shadow page walking >> >> Signed-off-by: Xiao Guangrong >> --- >> arch/x86/kvm/mmu.c | 40 ++++++++++++++++++++++++++++++++++------ >> 1 files changed, 34 insertions(+), 6 deletions(-) >> >> diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c >> index 0c6e92d..8b71908 100644 >> --- a/arch/x86/kvm/mmu.c >> +++ b/arch/x86/kvm/mmu.c >> @@ -796,7 +796,9 @@ static int mapping_level(struct kvm_vcpu *vcpu, gfn_t large_gfn) >> return level - 1; >> } >> >> -#define PTE_LIST_DESC (0x1ull) >> +#define PTE_LIST_DESC_BIT 0 >> +#define PTE_LIST_WP_BIT 1 > > _BIT ? What is the problem? > >> @@ -2291,9 +2310,15 @@ static int mmu_need_write_protect(struct kvm_vcpu *vcpu, gfn_t gfn, >> { >> struct kvm_mmu_page *s; >> struct hlist_node *node; >> + unsigned long *rmap; >> bool need_unsync = false; >> >> + rmap = gfn_to_rmap(vcpu->kvm, gfn, PT_PAGE_TABLE_LEVEL); > > Please use consistent variable names. > > In other parts of this patch, you are using rmapp for this. Okay.