Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by smtp.lore.kernel.org (Postfix) with ESMTP id 8BCB5C61DA4 for ; Mon, 6 Mar 2023 13:10:54 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230523AbjCFNKx (ORCPT ); Mon, 6 Mar 2023 08:10:53 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46506 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230519AbjCFNKv (ORCPT ); Mon, 6 Mar 2023 08:10:51 -0500 Received: from foss.arm.com (foss.arm.com [217.140.110.172]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 3103D2C650 for ; Mon, 6 Mar 2023 05:10:39 -0800 (PST) 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 C90EE12FC; Mon, 6 Mar 2023 05:11:22 -0800 (PST) Received: from localhost (ionvoi01-desktop.cambridge.arm.com [10.1.196.65]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 0DE5A3F885; Mon, 6 Mar 2023 05:10:38 -0800 (PST) Date: Mon, 6 Mar 2023 13:10:37 +0000 From: Ionela Voinescu To: Ricardo Neri Cc: "Peter Zijlstra (Intel)" , Juri Lelli , Vincent Guittot , Ricardo Neri , "Ravi V. Shankar" , Ben Segall , Daniel Bristot de Oliveira , Dietmar Eggemann , Len Brown , Mel Gorman , "Rafael J. Wysocki" , Srinivas Pandruvada , Steven Rostedt , Tim Chen , Valentin Schneider , x86@kernel.org, linux-kernel@vger.kernel.org, "Tim C . Chen" Subject: Re: [PATCH v3 08/10] sched/topology: Remove SHARED_CHILD from ASYM_PACKING Message-ID: References: <20230207045838.11243-1-ricardo.neri-calderon@linux.intel.com> <20230207045838.11243-9-ricardo.neri-calderon@linux.intel.com> <20230305190811.GA4352@ranerica-svr.sc.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20230305190811.GA4352@ranerica-svr.sc.intel.com> Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hey, On Sunday 05 Mar 2023 at 11:08:11 (-0800), Ricardo Neri wrote: > On Fri, Mar 03, 2023 at 11:29:52AM +0000, Ionela Voinescu wrote: > > Hi Ricardo, > > Hi Ionela! > > > > > On Monday 06 Feb 2023 at 20:58:36 (-0800), Ricardo Neri wrote: > > > Only x86 and Power7 use ASYM_PACKING. They use it differently. > > > > > > Power7 has cores of equal priority, but the SMT siblings of a core have > > > different priorities. Parent scheduling domains do not need (nor have) the > > > ASYM_PACKING flag. SHARED_CHILD is not needed. Using SHARED_PARENT would > > > cause the topology debug code to complain. > > > > > > X86 has cores of different priority, but all the SMT siblings of the core > > > have equal priority. It needs ASYM_PACKING at the MC level, but not at the > > > SMT level (it also needs it at upper levels if they have scheduling groups > > > of different priority). Removing ASYM_PACKING from the SMT domain causes > > > the topology debug code to complain. > > > > > > Remove SHARED_CHILD for now. We still need a topology check that satisfies > > > both architectures. > > > > > > Cc: Ben Segall > > > Cc: Daniel Bristot de Oliveira > > > Cc: Dietmar Eggemann > > > Cc: Len Brown > > > Cc: Mel Gorman > > > Cc: Rafael J. Wysocki > > > Cc: Srinivas Pandruvada > > > Cc: Steven Rostedt > > > Cc: Tim C. Chen > > > Cc: Valentin Schneider > > > Cc: x86@kernel.org > > > Cc: linux-kernel@vger.kernel.org > > > Suggested-by: Valentin Schneider > > > Signed-off-by: Ricardo Neri > > > --- > > > Changes since v2: > > > * Introduced this patch. > > > > > > Changes since v1: > > > * N/A > > > --- > > > include/linux/sched/sd_flags.h | 5 +---- > > > 1 file changed, 1 insertion(+), 4 deletions(-) > > > > > > diff --git a/include/linux/sched/sd_flags.h b/include/linux/sched/sd_flags.h > > > index 57bde66d95f7..800238854ba5 100644 > > > --- a/include/linux/sched/sd_flags.h > > > +++ b/include/linux/sched/sd_flags.h > > > @@ -132,12 +132,9 @@ SD_FLAG(SD_SERIALIZE, SDF_SHARED_PARENT | SDF_NEEDS_GROUPS) > > > /* > > > * Place busy tasks earlier in the domain > > > * > > > - * SHARED_CHILD: Usually set on the SMT level. Technically could be set further > > > - * up, but currently assumed to be set from the base domain > > > - * upwards (see update_top_cache_domain()). > > > * NEEDS_GROUPS: Load balancing flag. > > > */ > > > -SD_FLAG(SD_ASYM_PACKING, SDF_SHARED_CHILD | SDF_NEEDS_GROUPS) > > > +SD_FLAG(SD_ASYM_PACKING, SDF_NEEDS_GROUPS) > > > > While this silences the warning one would have gotten when removing > > SD_ASYM_PACKING from SMT level, it will still result in sd_asym_packing > > being NULL for these systems, which breaks nohz balance. That is because > > highest_flag_domain() still stops searching at the first level without > > the flag set, in this case SMT, even if levels above have the flag set. > > You are absolutely right! This how this whole discussion started. It > slipped my mind. > > > > > Maybe highest_flag_domain() should be changed to take into account the > > metadata flags? > > What about the patch below? Search will stop if the flag has > SDF_SHARED_CHILD as it does today. Otherwise it will search all the > domains. > > --- a/kernel/sched/sched.h > +++ b/kernel/sched/sched.h > @@ -1773,6 +1773,12 @@ queue_balance_callback(struct rq *rq, > for (__sd = rcu_dereference_check_sched_domain(cpu_rq(cpu)->sd); \ > __sd; __sd = __sd->parent) > > +#define SD_FLAG(name, mflags) (name * !!((mflags) & SDF_SHARED_CHILD)) | > +static const unsigned int SD_SHARED_CHILD_MASK = > +#include > +0; > +#undef SD_FLAG > + > /** > * highest_flag_domain - Return highest sched_domain containing flag. > * @cpu: The CPU whose highest level of sched domain is to > @@ -1781,15 +1787,19 @@ queue_balance_callback(struct rq *rq, > * for the given CPU. > * > * Returns the highest sched_domain of a CPU which contains the given flag. > - */ > +*/ ^^^ likely an unintended change > static inline struct sched_domain *highest_flag_domain(int cpu, int flag) > { > struct sched_domain *sd, *hsd = NULL; > > for_each_domain(cpu, sd) { > - if (!(sd->flags & flag)) > + if (sd->flags & flag) { > + hsd = sd; > + continue; > + } > + There might be room for a comment here: /* * If the flag is not set and is known to be shared with lower * domains, stop the search, as it won't be found further up. */ > + if (flag & SD_SHARED_CHILD_MASK) > break; > - hsd = sd; > } > > return hsd; It looks nice and sane to me - I've not compiled or tested it :). Thanks, Ionela. > > > > > Thanks, > > Ionela. > > > > > > > > /* > > > * Prefer to place tasks in a sibling domain > > > -- > > > 2.25.1 > > > > > >