kvm.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* [PATCH][v3] KVM: x86/mmu: fix counting of rmap entries in pte_list_add
@ 2020-09-27  8:44 Li RongQing
  2020-10-23  1:57 ` Li,Rongqing
  0 siblings, 1 reply; 3+ messages in thread
From: Li RongQing @ 2020-09-27  8:44 UTC (permalink / raw)
  To: lirongqing, kvm, x86, sean.j.christopherson

Fix an off-by-one style bug in pte_list_add() where it failed to
account the last full set of SPTEs, i.e. when desc->sptes is full
and desc->more is NULL.

Merge the two "PTE_LIST_EXT-1" checks as part of the fix to avoid
an extra comparison.

Signed-off-by: Li RongQing <lirongqing@baidu.com>
Reviewed-by: Sean Christopherson <sean.j.christopherson@intel.com>
---
v2: Sean suggest to merge the two "PTE_LIST_EXT-1" checks
v3: Sean suggest to rewrite commit header

 arch/x86/kvm/mmu/mmu.c | 12 +++++++-----
 1 file changed, 7 insertions(+), 5 deletions(-)

diff --git a/arch/x86/kvm/mmu/mmu.c b/arch/x86/kvm/mmu/mmu.c
index a5d0207e7189..c4068be6bb3f 100644
--- a/arch/x86/kvm/mmu/mmu.c
+++ b/arch/x86/kvm/mmu/mmu.c
@@ -1273,12 +1273,14 @@ static int pte_list_add(struct kvm_vcpu *vcpu, u64 *spte,
 	} else {
 		rmap_printk("pte_list_add: %p %llx many->many\n", spte, *spte);
 		desc = (struct pte_list_desc *)(rmap_head->val & ~1ul);
-		while (desc->sptes[PTE_LIST_EXT-1] && desc->more) {
-			desc = desc->more;
+		while (desc->sptes[PTE_LIST_EXT-1]) {
 			count += PTE_LIST_EXT;
-		}
-		if (desc->sptes[PTE_LIST_EXT-1]) {
-			desc->more = mmu_alloc_pte_list_desc(vcpu);
+
+			if (!desc->more) {
+				desc->more = mmu_alloc_pte_list_desc(vcpu);
+				desc = desc->more;
+				break;
+			}
 			desc = desc->more;
 		}
 		for (i = 0; desc->sptes[i]; ++i)
-- 
2.16.2


^ permalink raw reply related	[flat|nested] 3+ messages in thread

* RE: [PATCH][v3] KVM: x86/mmu: fix counting of rmap entries in pte_list_add
  2020-09-27  8:44 [PATCH][v3] KVM: x86/mmu: fix counting of rmap entries in pte_list_add Li RongQing
@ 2020-10-23  1:57 ` Li,Rongqing
  2020-11-06 11:56   ` Paolo Bonzini
  0 siblings, 1 reply; 3+ messages in thread
From: Li,Rongqing @ 2020-10-23  1:57 UTC (permalink / raw)
  To: kvm, x86, sean.j.christopherson, Paolo Bonzini



> -----Original Message-----
> From: Li,Rongqing
> Sent: Sunday, September 27, 2020 4:45 PM
> To: Li,Rongqing <lirongqing@baidu.com>; kvm@vger.kernel.org;
> x86@kernel.org; sean.j.christopherson@intel.com
> Subject: [PATCH][v3] KVM: x86/mmu: fix counting of rmap entries in
> pte_list_add
> 
> Fix an off-by-one style bug in pte_list_add() where it failed to account the last
> full set of SPTEs, i.e. when desc->sptes is full and desc->more is NULL.
> 
> Merge the two "PTE_LIST_EXT-1" checks as part of the fix to avoid an extra
> comparison.
> 
> Signed-off-by: Li RongQing <lirongqing@baidu.com>
> Reviewed-by: Sean Christopherson <sean.j.christopherson@intel.com>


Ping 


Thanks

-Li

^ permalink raw reply	[flat|nested] 3+ messages in thread

* Re: [PATCH][v3] KVM: x86/mmu: fix counting of rmap entries in pte_list_add
  2020-10-23  1:57 ` Li,Rongqing
@ 2020-11-06 11:56   ` Paolo Bonzini
  0 siblings, 0 replies; 3+ messages in thread
From: Paolo Bonzini @ 2020-11-06 11:56 UTC (permalink / raw)
  To: Li,Rongqing, kvm, x86, sean.j.christopherson

On 23/10/20 03:57, Li,Rongqing wrote:
> 
> 
>> -----Original Message-----
>> From: Li,Rongqing
>> Sent: Sunday, September 27, 2020 4:45 PM
>> To: Li,Rongqing <lirongqing@baidu.com>; kvm@vger.kernel.org;
>> x86@kernel.org; sean.j.christopherson@intel.com
>> Subject: [PATCH][v3] KVM: x86/mmu: fix counting of rmap entries in
>> pte_list_add
>>
>> Fix an off-by-one style bug in pte_list_add() where it failed to account the last
>> full set of SPTEs, i.e. when desc->sptes is full and desc->more is NULL.
>>
>> Merge the two "PTE_LIST_EXT-1" checks as part of the fix to avoid an extra
>> comparison.
>>
>> Signed-off-by: Li RongQing <lirongqing@baidu.com>
>> Reviewed-by: Sean Christopherson <sean.j.christopherson@intel.com>
> 
> 
> Ping
> 
> 
> Thanks
> 
> -Li
> 

Queued, thanks.

Paolo


^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2020-11-06 11:56 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2020-09-27  8:44 [PATCH][v3] KVM: x86/mmu: fix counting of rmap entries in pte_list_add Li RongQing
2020-10-23  1:57 ` Li,Rongqing
2020-11-06 11:56   ` Paolo Bonzini

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).