Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp1408725pxx; Fri, 30 Oct 2020 09:16:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz6eVJfJqT2HSKEDi2YQfn4n0ca0RJS7R74hIWnXPOGW51ETaIn5ia+/SBfIbGzz8qeROla X-Received: by 2002:a17:907:4302:: with SMTP id nh2mr182925ejb.451.1604074619580; Fri, 30 Oct 2020 09:16:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1604074619; cv=none; d=google.com; s=arc-20160816; b=rjzF4GNJ/cLBSohHREE9vhSZn9f2zR/IkHqMEKWbGie8wQwQiLXJY3KibCPTi2j8yn hKIAGVOYZTl40wjCaapEDPB+7/Y7rvJtf4+QnTaO7jVj1IpKG/9umD0SSOeGmt3F8214 dWDlp14oVC6vT1MfFbWuXrJxqZnpuBr6ssbCYjzcihpEgCknCE9VGubSUW16TGFOTCup HoULVaGshaN1azmghvU3h/n7bHkkbN/QBNhI4QeNiW2UOmTExWNaLj9UAJQP2iOE5VJW QBC+ERHwtA6YqNDED+MgdgEnCbOpVk4zbnR4OM2leaKQxoY4bOU+l3I9TPsJkBLQQZa1 h4Ag== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=IK3QWZr07B20zov/r93CtsD29YeVkk1+n9YK+3EzVNU=; b=OzovLMxhpyXdVb/QWg/jMgx9fmP+G/n05IQDgnS1AVhNxC4stXef59oHur5bZOiN+W cMXxL9lVciASEUv9KetzK9q4gmyL10PQfdKQNoNCA/3SV7D8/4XITJjcf96/6y1d/nB4 glnpF4UFN+anHcknNWxE7xKwW3rqLhmDHVHQRcYUlGtPNTYStLC2Y/JHixRBgNDzpWOc j/i3KgdaJeOOF+WHni55vScPMUoLnV58/sdx9tR4SgpvpiesAHrBbATApzA8cfaiPPIw 3lyXh+kkAyHA6mS+IgbD4hIHJQOuSox3PjLzf1xpYQj0pnQLWMbMNIJGJrIjRyWZH1XP HstQ== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id o26si1518977edr.157.2020.10.30.09.16.36; Fri, 30 Oct 2020 09:16:59 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=arm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727266AbgJ3QNV (ORCPT + 99 others); Fri, 30 Oct 2020 12:13:21 -0400 Received: from foss.arm.com ([217.140.110.172]:39284 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727250AbgJ3QNT (ORCPT ); Fri, 30 Oct 2020 12:13:19 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 641BD1684; Fri, 30 Oct 2020 09:13:18 -0700 (PDT) Received: from eglon.eretz (unknown [172.31.20.19]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 825CB3F719; Fri, 30 Oct 2020 09:13:16 -0700 (PDT) From: James Morse To: x86@kernel.org, linux-kernel@vger.kernel.org Cc: Fenghua Yu , Reinette Chatre , Thomas Gleixner , Ingo Molnar , Borislav Petkov , shameerali.kolothum.thodi@huawei.com, Jamie Iles , D Scott Phillips OS , James Morse Subject: [PATCH 22/24] x86/resctrl: Merge the ctrlval arrays Date: Fri, 30 Oct 2020 16:11:18 +0000 Message-Id: <20201030161120.227225-23-james.morse@arm.com> X-Mailer: git-send-email 2.28.0 In-Reply-To: <20201030161120.227225-1-james.morse@arm.com> References: <20201030161120.227225-1-james.morse@arm.com> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Now that the CODE/DATA resources don't use overlapping slots in the ctrlval arrays, they can be merged. This allows the cdp_peer configuration to be read from any resource's domain, instead of searching for the matching flavour. Add a helper to allocate the ctrlval array, that returns the value on the L2 or L3 resource if it already exists. This gets removed once the resources are merged, and there really is only one ctrlval array. Signed-off-by: James Morse --- arch/x86/kernel/cpu/resctrl/core.c | 79 +++++++++++++++++++++++++++--- 1 file changed, 72 insertions(+), 7 deletions(-) diff --git a/arch/x86/kernel/cpu/resctrl/core.c b/arch/x86/kernel/cpu/resctrl/core.c index e2f5ea129be2..01d010977367 100644 --- a/arch/x86/kernel/cpu/resctrl/core.c +++ b/arch/x86/kernel/cpu/resctrl/core.c @@ -509,6 +509,72 @@ void setup_default_ctrlval(struct rdt_resource *r, u32 *dc, u32 *dm) } } +/* + * temporary. + * This relies on L2 or L3 being allocated before their CODE/DATA aliases + */ +static u32 *alloc_ctrlval_array(struct rdt_resource *r, struct rdt_domain *d, + bool mba_sc) +{ + /* these are for the underlying hardware, they may not match r/d */ + struct rdt_domain *underlying_domain; + struct rdt_hw_resource *hw_res; + struct rdt_hw_domain *hw_dom; + bool remapped; + + switch (r->rid) { + case RDT_RESOURCE_L3DATA: + case RDT_RESOURCE_L3CODE: + hw_res = &rdt_resources_all[RDT_RESOURCE_L3]; + remapped = true; + break; + case RDT_RESOURCE_L2DATA: + case RDT_RESOURCE_L2CODE: + hw_res = &rdt_resources_all[RDT_RESOURCE_L2]; + remapped = true; + break; + default: + hw_res = resctrl_to_arch_res(r); + remapped = false; + } + + /* + * If we changed the resource, we need to search for the underlying + * domain. Doing this for all resources would make it tricky to add the + * first resource, as domains aren't added to a resource list until + * after the ctrlval arrays have been allocated. + */ + if (remapped) + underlying_domain = rdt_find_domain(&hw_res->resctrl, d->id, + NULL); + else + underlying_domain = d; + hw_dom = resctrl_to_arch_dom(underlying_domain); + + if (mba_sc) { + if (hw_dom->mbps_val) + return hw_dom->mbps_val; + return kmalloc_array(hw_res->num_closid, + sizeof(*hw_dom->mbps_val), GFP_KERNEL); + } else { + if (hw_dom->ctrl_val) + return hw_dom->ctrl_val; + return kmalloc_array(hw_res->num_closid, + sizeof(*hw_dom->ctrl_val), GFP_KERNEL); + } +} + +/* Only kfree() for L2/L3, not the CODE/DATA aliases */ +static void free_ctrlval_arrays(struct rdt_resource *r, struct rdt_domain *d) +{ + struct rdt_hw_domain *hw_dom = resctrl_to_arch_dom(d); + + if (r->rid == RDT_RESOURCE_L2 || r->rid == RDT_RESOURCE_L3) { + kfree(hw_dom->ctrl_val); + kfree(hw_dom->mbps_val); + } +} + static int domain_setup_ctrlval(struct rdt_resource *r, struct rdt_domain *d) { struct rdt_hw_resource *hw_res = resctrl_to_arch_res(r); @@ -516,18 +582,18 @@ static int domain_setup_ctrlval(struct rdt_resource *r, struct rdt_domain *d) struct msr_param m; u32 *dc, *dm; - dc = kmalloc_array(hw_res->num_closid, sizeof(*hw_dom->ctrl_val), GFP_KERNEL); + dc = alloc_ctrlval_array(r, d, false); if (!dc) return -ENOMEM; + hw_dom->ctrl_val = dc; - dm = kmalloc_array(hw_res->num_closid, sizeof(*hw_dom->mbps_val), GFP_KERNEL); + dm = alloc_ctrlval_array(r, d, true); if (!dm) { - kfree(dc); + free_ctrlval_arrays(r, d); return -ENOMEM; } - - hw_dom->ctrl_val = dc; hw_dom->mbps_val = dm; + setup_default_ctrlval(r, dc, dm); m.low = 0; @@ -677,8 +743,7 @@ static void domain_remove_cpu(int cpu, struct rdt_resource *r) if (d->plr) d->plr->d = NULL; - kfree(hw_dom->ctrl_val); - kfree(hw_dom->mbps_val); + free_ctrlval_arrays(r, d); bitmap_free(d->rmid_busy_llc); kfree(d->mbm_total); kfree(d->mbm_local); -- 2.28.0