Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S934049AbbLPHil (ORCPT ); Wed, 16 Dec 2015 02:38:41 -0500 Received: from mga09.intel.com ([134.134.136.24]:5370 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932681AbbLPHik (ORCPT ); Wed, 16 Dec 2015 02:38:40 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.20,436,1444719600"; d="scan'208";a="872505751" Subject: Re: [PATCH 04/11] KVM: page track: add the framework of guest page tracking To: Xiao Guangrong , pbonzini@redhat.com References: <1448907973-36066-1-git-send-email-guangrong.xiao@linux.intel.com> <1448907973-36066-5-git-send-email-guangrong.xiao@linux.intel.com> <566FBC0F.9060908@linux.intel.com> <566FD377.8040903@linux.intel.com> Cc: gleb@kernel.org, mtosatti@redhat.com, kvm@vger.kernel.org, linux-kernel@vger.kernel.org From: Kai Huang Message-ID: <567113BE.2000207@linux.intel.com> Date: Wed, 16 Dec 2015 15:33:18 +0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.4.0 MIME-Version: 1.0 In-Reply-To: <566FD377.8040903@linux.intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 3582 Lines: 115 On 12/15/2015 04:46 PM, Xiao Guangrong wrote: > > > On 12/15/2015 03:06 PM, Kai Huang wrote: >> Hi Guangrong, >> >> I am starting to review this series, and should have some comments or >> questions, you can determine >> whether they are valuable :) > > Thank you very much for your review and breaking the silent on this > patchset. ;) > > >>> +static void page_track_slot_free(struct kvm_memory_slot *slot) >>> +{ >>> + int i; >>> + >>> + for (i = 0; i < KVM_PAGE_TRACK_MAX; i++) >>> + if (slot->arch.gfn_track[i]) { >>> + kvfree(slot->arch.gfn_track[i]); >>> + slot->arch.gfn_track[i] = NULL; >>> + } >>> +} >>> + >>> +int kvm_page_track_create_memslot(struct kvm_memory_slot *slot, >>> + unsigned long npages) >>> +{ >>> + int i, pages = gfn_to_index(slot->base_gfn + npages - 1, >>> + slot->base_gfn, PT_PAGE_TABLE_LEVEL) + 1; >>> + >>> + for (i = 0; i < KVM_PAGE_TRACK_MAX; i++) { >>> + slot->arch.gfn_track[i] = kvm_kvzalloc(pages * >>> + sizeof(*slot->arch.gfn_track[i])); >>> + if (!slot->arch.gfn_track[i]) >>> + goto track_free; >>> + } >>> + >>> + return 0; >>> + >>> +track_free: >>> + page_track_slot_free(slot); >>> + return -ENOMEM; >>> +} >> Is it necessary to use the 'unsigned long npages' pareameter? In my >> understanding you are going to > > The type, 'int', is used here as I followed the style of 'struct > kvm_lpage_info'. > > 4 bytes should be enough to track all users and signed type is good to > track > overflow. > >> track all GFNs in the memory slot anyway, right? If you want to keep >> npages, I think it's better to >> add a base_gfn as well otherwise you are assuming you are going to >> track the npages GFN starting >> from slot->base_gfn. > > Yes, any page in the memslot may be tracked so that there is a index > for every > page. > >> >>> + >>> +void kvm_page_track_free_memslot(struct kvm_memory_slot *free, >>> + struct kvm_memory_slot *dont) >>> +{ >>> + if (!dont || free->arch.gfn_track != dont->arch.gfn_track) >>> + page_track_slot_free(free); >>> +} >>> diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c >>> index c04987e..ad4888a 100644 >>> --- a/arch/x86/kvm/x86.c >>> +++ b/arch/x86/kvm/x86.c >>> @@ -7838,6 +7838,8 @@ void kvm_arch_free_memslot(struct kvm *kvm, >>> struct kvm_memory_slot *free, >>> free->arch.lpage_info[i - 1] = NULL; >>> } >>> } >>> + >>> + kvm_page_track_free_memslot(free, dont); >>> } >>> int kvm_arch_create_memslot(struct kvm *kvm, struct >>> kvm_memory_slot *slot, >>> @@ -7886,6 +7888,9 @@ int kvm_arch_create_memslot(struct kvm *kvm, >>> struct kvm_memory_slot *slot, >>> } >>> } >>> + if (kvm_page_track_create_memslot(slot, npages)) >>> + goto out_free; >>> + >> Looks essentially you are allocating one int for all GFNs of the slot >> unconditionally. In my >> understanding for most of memory slots, we are not going to track >> them, so isn't it going to be >> wasteful of memory? >> > > Yes, hmm... maybe we can make the index as "unsigned short" then 1G > memory only needs 512k index > buffer. It is not so unacceptable. Those comments are really minor and don't bother on this :) Thanks, -Kai -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/