Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp40364pxj; Thu, 13 May 2021 20:20:34 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxl8H3czJ/eVsJ6KU3gAqQA1KVr3X6hZjjrlcqsPaI7I0j0plq19KX4XfGn7vb7ubNDahdT X-Received: by 2002:a92:c607:: with SMTP id p7mr422279ilm.242.1620962434438; Thu, 13 May 2021 20:20:34 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620962434; cv=none; d=google.com; s=arc-20160816; b=LRkdo4H3dZUb7FsnZuJC5jeAGAtJYGY262DvPoVBNLVa4OMMdOQvwRVzqQCD23xj/m ZLMKB0uyQeZofhmkcJHn8kPbwevHbGVbX+K1tj4w3l/hbwuzNGC/GxZVBIHe+khwIzcH tbi0+lXMvVqNOFkhXH3vj6xxNYbXpy0hxPe89d3U6Eo337ZKoNJa2hsklIocoEF+uwCk dQf2xkG+GwZRZwTR9/LdF4SfqJi2JTPUUAFLc2muj0wIu4DMIcCSu84mn5Y0tuJahti4 9CnETYBpwruwk4P/iizCKZmh+2wGe8EI/ZabruZnFQR4EYm0zQGU40ZVcgmOBx4URF0d NPrQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:references:in-reply-to:message-id:date:subject :cc:to:from:ironport-sdr:ironport-sdr; bh=0UCao0T1YYQ2mMt5r1xmWqmjU4U2Es9mQsSlQJ/lAug=; b=V5ZOBsLCrn7TliNub+LIT21QqWvNm/fwUw9r4EUESnvhStyHS/f/VnxlxIT9pZTYrp PEYgDCofNEIi4Z1SJruUMa0KtAJuy4B0mRAlYuVFuJD+XQrV/MpMg9/iX9I6dXD2elP0 Odle/AKYfcG7DA7kb91CyAsuU2wZXDTdSupdOa10tl5w+/BcnI24X9BylIalnYDfwJai gYZy//CiM+1tJub8VkqoH/q3+GNLC2r8OaIDcSl09z46CBh1y6U/8PhIReWRSRfG+Ii2 FkuMeBSi6NxakDVxWRFMwBu1Qd+HxY+fhr4O/NtQcW1qiCryimJetRomeXb85Sa5t/HW VSRA== 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=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x17si4886386jan.67.2021.05.13.20.20.20; Thu, 13 May 2021 20:20:34 -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=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232649AbhEMPvR (ORCPT + 99 others); Thu, 13 May 2021 11:51:17 -0400 Received: from mga12.intel.com ([192.55.52.136]:24114 "EHLO mga12.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231146AbhEMPvL (ORCPT ); Thu, 13 May 2021 11:51:11 -0400 IronPort-SDR: Yurrh/jaGsPedI2v9JOnPeHrniGLKJzZYaMwDNH5U+nQ09FKaxLOiS6oHTC6Ow0mOtGQ9agWuB PPfH5a52wIQA== X-IronPort-AV: E=McAfee;i="6200,9189,9982"; a="179568912" X-IronPort-AV: E=Sophos;i="5.82,296,1613462400"; d="scan'208";a="179568912" Received: from orsmga005.jf.intel.com ([10.7.209.41]) by fmsmga106.fm.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 13 May 2021 08:50:00 -0700 IronPort-SDR: q7QczRcl1XBX4sxwj+cgkQE//bgGGfiL3J03CmVzNgU6C8uVs81nnIHNESe1rENMF/0qvDyJIa 3IPqGEL/Ydew== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.82,296,1613462400"; d="scan'208";a="610418838" Received: from ranerica-svr.sc.intel.com ([172.25.110.23]) by orsmga005.jf.intel.com with ESMTP; 13 May 2021 08:50:00 -0700 From: Ricardo Neri To: "Peter Zijlstra (Intel)" , Ingo Molnar , Juri Lelli , Vincent Guittot Cc: Dietmar Eggemann , Steven Rostedt , Ben Segall , Mel Gorman , Len Brown , Srinivas Pandruvada , Tim Chen , Aubrey Li , "Ravi V. Shankar" , Ricardo Neri , Quentin Perret , "Joel Fernandes (Google)" , linux-kernel@vger.kernel.org, Ricardo Neri , Aubrey Li , Daniel Bristot de Oliveira Subject: [PATCH v3 4/6] sched/fair: Carve out logic to mark a group for asymmetric packing Date: Thu, 13 May 2021 08:49:07 -0700 Message-Id: <20210513154909.6385-5-ricardo.neri-calderon@linux.intel.com> X-Mailer: git-send-email 2.17.1 In-Reply-To: <20210513154909.6385-1-ricardo.neri-calderon@linux.intel.com> References: <20210513154909.6385-1-ricardo.neri-calderon@linux.intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Currently when balancing load, a candidate busiest group is marked for asymmetric packing if, among other factors, dst_cpu has higher priority than the preferred CPU of the candidate busiest group. However, other factors influence the decision, such as the state of the SMT siblings of dst_cpu, if any. Thus, create a separate function, sched_asym(), in which logic for such decisions can be implemented. A subsequent changeset will introduce logic to deal with SMT. Cc: Aubrey Li Cc: Ben Segall Cc: Daniel Bristot de Oliveira Cc: Dietmar Eggemann Cc: Joel Fernandes (Google) Cc: Len Brown Cc: Mel Gorman Cc: Quentin Perret Cc: Srinivas Pandruvada Cc: Steven Rostedt Cc: Tim Chen Co-developed-by: Peter Zijlstra (Intel) Signed-off-by: Peter Zijlstra (Intel) Signed-off-by: Ricardo Neri --- Changes since v2: * Introduced this patch. Changes since v1: * N/A --- kernel/sched/fair.c | 27 ++++++++++++++++++++------- 1 file changed, 20 insertions(+), 7 deletions(-) diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c index c8c04e9d0d3b..c8b66a5d593e 100644 --- a/kernel/sched/fair.c +++ b/kernel/sched/fair.c @@ -8447,6 +8447,20 @@ group_type group_classify(unsigned int imbalance_pct, return group_has_spare; } +static inline bool +sched_asym(struct lb_env *env, struct sd_lb_stats *sds, struct sg_lb_stats *sgs, + struct sched_group *group) +{ + /* + * Because sd->groups starts with the local group, anything that isn't + * the local group will have access to the local state. + */ + if (group == sds->local) + return false; + + return sched_asym_prefer(env->dst_cpu, group->asym_prefer_cpu); +} + /** * update_sg_lb_stats - Update sched_group's statistics for load balancing. * @env: The load balancing environment. @@ -8507,18 +8521,17 @@ static inline void update_sg_lb_stats(struct lb_env *env, } } + sgs->group_capacity = group->sgc->capacity; + + sgs->group_weight = group->group_weight; + /* Check if dst CPU is idle and preferred to this group */ if (!local_group && env->sd->flags & SD_ASYM_PACKING && - env->idle != CPU_NOT_IDLE && - sgs->sum_h_nr_running && - sched_asym_prefer(env->dst_cpu, group->asym_prefer_cpu)) { + env->idle != CPU_NOT_IDLE && sgs->sum_h_nr_running && + sched_asym(env, sds, sgs, group)) { sgs->group_asym_packing = 1; } - sgs->group_capacity = group->sgc->capacity; - - sgs->group_weight = group->group_weight; - sgs->group_type = group_classify(env->sd->imbalance_pct, group, sgs); /* Computing avg_load makes sense only when group is overloaded */ -- 2.17.1