Received: by 2002:a05:6a10:a852:0:0:0:0 with SMTP id d18csp1670332pxy; Thu, 6 May 2021 12:52:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyrVaHSpey6BZwKL20dt6ZjPn9N+hm3UINuJxpKQXwecpawWWpoMngDgfUd+OJOYNcgAiRP X-Received: by 2002:a17:906:d8d7:: with SMTP id re23mr6213419ejb.467.1620330733947; Thu, 06 May 2021 12:52:13 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620330733; cv=none; d=google.com; s=arc-20160816; b=BAY1GM9Q4taJXGBut+z8FS1PlivFnl0kMIUbi03gO4xlQl/5nTbsoU1ff/bI52vPup Iev8AFuRnlRaet1RKzOzlXgI0GLh9C/gh9ETKLydveccy5mWbMkOb4gHWl+jr19dSU2V Amh6S6bzYuyHUt0hUobRGQYkWl3q9mpxeA9j0K9gFbl2LoQijOIcAIVxaWskVVXF7Sai aZ7yyjsmU0p6fBoivG2JGukM8nnAc04fnxOyxgcsvGVRpGBAS1t0eAiQ2rNwXVuhn4cg ik+KlYvRNxm5JqlDJNW9qGhvNsc1oJ6+CN2sNWVlRaONUymg15c4KixQkR4H7LFOTuG2 kZ6Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:from:subject:references:mime-version :message-id:in-reply-to:date:dkim-signature; bh=IvlR4TwLPb1VTfZLUATWctM7vw/E1uak9fxPDAc2C68=; b=tr6sDKV9KdG4k0QApGHAeQ/og3GMOwhXgEPMJWi1+mCbERnaKab1nIwOVcwNZCNbcz pqrCoIgr0W+ahmajlE2pmsXZkks0OtGVqLMk7tOz/AJHSwf78bM4/50yvmbTzvqHYf/C Z6AZrApLflLPQ6GVbMn1RFMx5Ey/u6SUw9MvQoDDo9fG1hVnnJWmT/pCFqGpuKhe/q7P x7AK3KV//m4KoCeRg2H5Wd1v+s0OSGXcFyJgrwiPaBMMD7hMNgYVzfoRNgSCsBxeToLF /fldhaXBhEIUxXmnZa9AA4pF9yIt60Dpc9i3lJU6v4FYzZ78se5I79O2SPU4GCiLNahv 11jA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b="qLvTttI/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id i3si3235342ejb.338.2021.05.06.12.51.47; Thu, 06 May 2021 12:52:13 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b="qLvTttI/"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S236411AbhEFSnz (ORCPT + 99 others); Thu, 6 May 2021 14:43:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48028 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S236409AbhEFSny (ORCPT ); Thu, 6 May 2021 14:43:54 -0400 Received: from mail-qk1-x749.google.com (mail-qk1-x749.google.com [IPv6:2607:f8b0:4864:20::749]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2047FC0613ED for ; Thu, 6 May 2021 11:42:56 -0700 (PDT) Received: by mail-qk1-x749.google.com with SMTP id e4-20020a37b5040000b02902df9a0070efso4132098qkf.18 for ; Thu, 06 May 2021 11:42:56 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:in-reply-to:message-id:mime-version:references:subject:from:to :cc; bh=IvlR4TwLPb1VTfZLUATWctM7vw/E1uak9fxPDAc2C68=; b=qLvTttI//vGOQKjhAI709uVWmJJX9PjDcNvEdKpoTe1nwekLzot7XmeC569I41AUbO Rf7RVyEVc2dcPUMvuXuiBsC+D2P+DhFJI2AzyTz/OKH9yoGN+B1eqk4dHpdFZrnGV4kw 5tGCsJbkXii/72IzIqNDFbSx9KuoVQ1ZoNE2z7KFv4eMYWdExYdSmzbVjpYO3rCTgyAC 4UiBN158gd9GrhhJCP6cS0ivDnOYzpGBev2fcUW1vLaiUXZyQmVWDpzvbToiQiK1hAx6 ToNtI7GQQ6juvF4oCH2A2/0En03LAz3qY2lQ/EqhDSmHYi9JCVYTk78hxjqwzsMK2hYe IDOQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:in-reply-to:message-id:mime-version :references:subject:from:to:cc; bh=IvlR4TwLPb1VTfZLUATWctM7vw/E1uak9fxPDAc2C68=; b=sYo5SPtnuvI/PvLdb2Tqq6JRsPCq6Da/vo1tAl2Pzpi9iO2KND9G98eDFCyckX/0Xz o+t9cSccdSZBxpvuE2YKcLfpYBaucuo6ezQ1DeKX2L/dMzq6x/Cy8PkzgX9BGi09zYJw MJilzG0+M3nDhqhBEoWgIhvkqS4zX466Q9hLi4l3IOnh6ntbc9x2Jou1R3Ztgyk2LSX2 LxxS0xfHLFFVnd5IsUDHagxtc3R2CMM6Z4JPa0Mw7pAJMO8BL5jrJlIAhlbPz5v/+pS+ dQP52obI/dzrOu/YO4tM+y+F5Nc4fCSrLvgFOsHMuvQQFql9ippvrDhwV9bJ05uqrkba 8toA== X-Gm-Message-State: AOAM533faKZCV39jzWp64fZOygJcgusrnxXP7SWs3iEjd28eoJ9CPwc4 /sZEbHC7DWG/iwVUQBcsVbYA3SRXxFzCqjgoTAnDo9mOtPM9Ihb7sLqLyk7LyfdzDjKJN7I0OA0 UlcRYHwUTzPT5xpiHgR4ViDZgdFvgImsgD2KLOeMEBIXt4pxJVXMr2C2245whFFSwbQJA4vki X-Received: from bgardon.sea.corp.google.com ([2620:15c:100:202:9258:9474:54ca:4500]) (user=bgardon job=sendgmr) by 2002:ad4:4d94:: with SMTP id cv20mr5913495qvb.26.1620326575260; Thu, 06 May 2021 11:42:55 -0700 (PDT) Date: Thu, 6 May 2021 11:42:35 -0700 In-Reply-To: <20210506184241.618958-1-bgardon@google.com> Message-Id: <20210506184241.618958-3-bgardon@google.com> Mime-Version: 1.0 References: <20210506184241.618958-1-bgardon@google.com> X-Mailer: git-send-email 2.31.1.607.g51e8a6a459-goog Subject: [PATCH v3 2/8] KVM: x86/mmu: Factor out allocating memslot rmap From: Ben Gardon To: linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: Paolo Bonzini , Peter Xu , Sean Christopherson , Peter Shier , Yulei Zhang , Wanpeng Li , Xiao Guangrong , Kai Huang , Keqian Zhu , Ben Gardon Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Small refactor to facilitate allocating rmaps for all memslots at once. No functional change expected. Signed-off-by: Ben Gardon --- arch/x86/kvm/x86.c | 41 ++++++++++++++++++++++++++++++++--------- 1 file changed, 32 insertions(+), 9 deletions(-) diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 5bcf07465c47..fc32a7dbe4c4 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -10842,10 +10842,37 @@ void kvm_arch_free_memslot(struct kvm *kvm, struct kvm_memory_slot *slot) kvm_page_track_free_memslot(slot); } +static int alloc_memslot_rmap(struct kvm_memory_slot *slot, + unsigned long npages) +{ + int i; + + for (i = 0; i < KVM_NR_PAGE_SIZES; ++i) { + int lpages; + int level = i + 1; + + lpages = gfn_to_index(slot->base_gfn + npages - 1, + slot->base_gfn, level) + 1; + + slot->arch.rmap[i] = + kvcalloc(lpages, sizeof(*slot->arch.rmap[i]), + GFP_KERNEL_ACCOUNT); + if (!slot->arch.rmap[i]) + goto out_free; + } + + return 0; + +out_free: + free_memslot_rmap(slot); + return -ENOMEM; +} + static int kvm_alloc_memslot_metadata(struct kvm_memory_slot *slot, unsigned long npages) { int i; + int r; /* * Clear out the previous array pointers for the KVM_MR_MOVE case. The @@ -10854,7 +10881,11 @@ static int kvm_alloc_memslot_metadata(struct kvm_memory_slot *slot, */ memset(&slot->arch, 0, sizeof(slot->arch)); - for (i = 0; i < KVM_NR_PAGE_SIZES; ++i) { + r = alloc_memslot_rmap(slot, npages); + if (r) + return r; + + for (i = 1; i < KVM_NR_PAGE_SIZES; ++i) { struct kvm_lpage_info *linfo; unsigned long ugfn; int lpages; @@ -10863,14 +10894,6 @@ static int kvm_alloc_memslot_metadata(struct kvm_memory_slot *slot, lpages = gfn_to_index(slot->base_gfn + npages - 1, slot->base_gfn, level) + 1; - slot->arch.rmap[i] = - kvcalloc(lpages, sizeof(*slot->arch.rmap[i]), - GFP_KERNEL_ACCOUNT); - if (!slot->arch.rmap[i]) - goto out_free; - if (i == 0) - continue; - linfo = kvcalloc(lpages, sizeof(*linfo), GFP_KERNEL_ACCOUNT); if (!linfo) goto out_free; -- 2.31.1.607.g51e8a6a459-goog