From mboxrd@z Thu Jan 1 00:00:00 1970 From: Avi Kivity Subject: Re: [PATCH v2 5/6] KVM: sort memslots by its size and use line search Date: Sun, 20 Nov 2011 13:27:58 +0200 Message-ID: <4EC8E43E.1040902@redhat.com> References: <4EC6226B.3080408@linux.vnet.ibm.com> <4EC62336.7040505@linux.vnet.ibm.com> <4EC8E3FB.7020108@redhat.com> Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit Cc: Marcelo Tosatti , LKML , KVM To: Xiao Guangrong Return-path: In-Reply-To: <4EC8E3FB.7020108@redhat.com> Sender: linux-kernel-owner@vger.kernel.org List-Id: kvm.vger.kernel.org On 11/20/2011 01:26 PM, Avi Kivity wrote: > > > > int kvm_vcpu_init(struct kvm_vcpu *vcpu, struct kvm *kvm, unsigned id); > > void kvm_vcpu_uninit(struct kvm_vcpu *vcpu); > > @@ -335,7 +340,14 @@ static inline struct kvm_memslots *kvm_memslots(struct kvm *kvm) > > static inline struct kvm_memory_slot * > > id_to_memslot(struct kvm_memslots *slots, int id) > > { > > - return &slots->memslots[id]; > > + int i; > > + > > + for (i = 0; i < KVM_MEM_SLOTS_NUM; i++) > > + if (slots->memslots[i].id == id) > > + return &slots->memslots[i]; > > + > > Is that in any hot path? we could make an array for doing this translation. Never mind, I see patch 6. I should have known you wouldn't leave it like that. -- error compiling committee.c: too many arguments to function