Received: by 2002:a05:6358:3188:b0:123:57c1:9b43 with SMTP id q8csp5407559rwd; Mon, 12 Jun 2023 04:53:30 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ7v02HLslq9/YtST0L6nKy4QE8EmofxApf0yHAUWw6MU+KgitlVvr3EYRT3xzaqQE1PvFKl X-Received: by 2002:a17:902:ab98:b0:1b1:9233:bbf5 with SMTP id f24-20020a170902ab9800b001b19233bbf5mr6244520plr.57.1686570810274; Mon, 12 Jun 2023 04:53:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1686570810; cv=none; d=google.com; s=arc-20160816; b=n4aWdzWfVRBlmMNrbo/mtOtshso5wRd4L252EDowNg3axrsQf0mmgIKfMthz4Rg2dN d2xiaWhkzjQR2L4HinOO149ZhQHWdcDNZp7NMgatc1MKW8/zUZU5R8AC7SpYB46u4Wut kdNNXJjPUgst1JPNSheExHkb8ulwo1DcJL0/I6CUxt5NzOOj4YJZREF5w4UMaGEsgAvf 8zvrdaWgLvDA3eqPXXmsJPy9lF+J7Zb1MrnnFPvihUFg7mBqzIPcnkV1W1TqtyG3cEx3 Hlh/Rucm8B497x93yxhYmcngmowzibkfMOPw2o+BSOiPCtV00tc9o4loDEfP9kUJvlW/ 85Cw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=MZfdnj2p3ESjPjuAdt5qtqvlnJmptetaTLnWFGztx/8=; b=N5/+ItyJEKj/LnXRcy1ceTtSxjr14DL607CwKu8DfRqd7CgYcGw+CZ6bZMfOW2cBfI EIoBSYS23FI7iHxOShucOB4+Vez/ZtsTwqF6Hr9S7jFizYaJj/+T+ot/mfoXuRmPi0G5 olrwtjHTACFy23VgkTnycdKLzcEFByKbZcJVjPU1fHiw/dEv/WLmjcXcNcWn1QkpH+lo vhBMMBRKEQuXksuKX7sJBn4Gtu7/LVW+LyyjrVVhxwkZWjeUD2QqKteffuaCSTGTjJnW d3iEnYVkM1cRAKpVwA7rn8vbv3MJ4mde1kJe6nNqR3PsRHO5CJWI8+P46+M1MoJGyYKz IimQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=desiato.20200630 header.b="D7nzu/Oh"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id z15-20020a170902d54f00b0019955f0dc48si6786823plf.527.2023.06.12.04.53.18; Mon, 12 Jun 2023 04:53:30 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@infradead.org header.s=desiato.20200630 header.b="D7nzu/Oh"; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232287AbjFLLjT (ORCPT + 99 others); Mon, 12 Jun 2023 07:39:19 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52708 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234892AbjFLLiW (ORCPT ); Mon, 12 Jun 2023 07:38:22 -0400 Received: from desiato.infradead.org (desiato.infradead.org [IPv6:2001:8b0:10b:1:d65d:64ff:fe57:4e05]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 069937EF8 for ; Mon, 12 Jun 2023 04:30:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=desiato.20200630; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=MZfdnj2p3ESjPjuAdt5qtqvlnJmptetaTLnWFGztx/8=; b=D7nzu/Oha8FGLyzs6OSF1OsnfV i0DBF6E8rGU0fCy7dAJmVne83GbD51uCJ5xJc/+2tOcgd2xfwEfBLenRIBkkZm1uHyaqqrKBDVy76 QxcETJzzYiWQDfM2yQqBF3wmxsCY0SN+9+gAuPg0VQEIuIZZeePyqaHFGvYJkSPqfX4lScc7U2SnU B54qr01ET7O0Y2zT5MljOSKBp8DNgljVhLdBtKM1GYr+OczwOk32OhAEj2vA4Q+G75u4rYc4PltQk skTES9MyK3ZYAPIZFJZ79VFzr2RP5qEbdxyBNxs+3EVxFg1IwgpRdqKoNgQOLyXY0cjFMgJny7MJL YZKYU4Og==; Received: from j130084.upc-j.chello.nl ([24.132.130.84] helo=noisy.programming.kicks-ass.net) by desiato.infradead.org with esmtpsa (Exim 4.96 #2 (Red Hat Linux)) id 1q8fk3-008nFj-04; Mon, 12 Jun 2023 11:29:47 +0000 Received: from hirez.programming.kicks-ass.net (hirez.programming.kicks-ass.net [192.168.1.225]) (using TLSv1.3 with cipher TLS_AES_256_GCM_SHA384 (256/256 bits) key-exchange X25519 server-signature RSA-PSS (4096 bits)) (Client did not present a certificate) by noisy.programming.kicks-ass.net (Postfix) with ESMTPS id 78D21300195; Mon, 12 Jun 2023 13:29:45 +0200 (CEST) Received: by hirez.programming.kicks-ass.net (Postfix, from userid 1000) id 5285124513501; Mon, 12 Jun 2023 13:29:45 +0200 (CEST) Date: Mon, 12 Jun 2023 13:29:45 +0200 From: Peter Zijlstra To: Tim Chen Cc: 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 , Valentin Schneider , Ionela Voinescu , x86@kernel.org, linux-kernel@vger.kernel.org, Shrikanth Hegde , Srikar Dronamraju , naveen.n.rao@linux.vnet.ibm.com, Yicong Yang , Barry Song , Chen Yu , Hillf Danton Subject: Re: [Patch v2 2/6] sched/topology: Record number of cores in sched group Message-ID: <20230612112945.GK4253@hirez.programming.kicks-ass.net> References: MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Jun 08, 2023 at 03:32:28PM -0700, Tim Chen wrote: > From: Tim C Chen > > When balancing sibling domains that have different number of cores, > tasks in respective sibling domain should be proportional to the number > of cores in each domain. In preparation of implementing such a policy, > record the number of tasks in a scheduling group. > > Signed-off-by: Tim Chen > --- > kernel/sched/sched.h | 1 + > kernel/sched/topology.c | 10 +++++++++- > 2 files changed, 10 insertions(+), 1 deletion(-) > > diff --git a/kernel/sched/sched.h b/kernel/sched/sched.h > index 3d0eb36350d2..5f7f36e45b87 100644 > --- a/kernel/sched/sched.h > +++ b/kernel/sched/sched.h > @@ -1860,6 +1860,7 @@ struct sched_group { > atomic_t ref; > > unsigned int group_weight; > + unsigned int cores; > struct sched_group_capacity *sgc; > int asym_prefer_cpu; /* CPU of highest priority in group */ > int flags; > diff --git a/kernel/sched/topology.c b/kernel/sched/topology.c > index 6d5628fcebcf..6b099dbdfb39 100644 > --- a/kernel/sched/topology.c > +++ b/kernel/sched/topology.c > @@ -1275,14 +1275,22 @@ build_sched_groups(struct sched_domain *sd, int cpu) > static void init_sched_groups_capacity(int cpu, struct sched_domain *sd) > { > struct sched_group *sg = sd->groups; > + struct cpumask *mask = sched_domains_tmpmask2; > > WARN_ON(!sg); > > do { > - int cpu, max_cpu = -1; > + int cpu, cores = 0, max_cpu = -1; > > sg->group_weight = cpumask_weight(sched_group_span(sg)); > > + cpumask_copy(mask, sched_group_span(sg)); > + for_each_cpu(cpu, mask) { > + cores++; > + cpumask_andnot(mask, mask, cpu_smt_mask(cpu)); > + } > + sg->cores = cores; > + > if (!(sd->flags & SD_ASYM_PACKING)) > goto next; Just a note; not sure we want or can do anything about this, but consider someone doing partitions like: [0,1] [2,3] [3,6] [------] [------] That is, 3 SMT cores, and 2 partitions splitting an SMT core in two. Then the domain trees will see either 2 or 3 but not the fully core. I'm perfectly fine with saying: don't do that then.