Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp2088193pxk; Mon, 14 Sep 2020 04:34:36 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzN8A1AWeFZ39HEbD7ckUNiC/gsFVO5MhP3hxfOVkEcn0tQJO4utFwT27gfdDheyHzOLOFf X-Received: by 2002:a17:906:7688:: with SMTP id o8mr14051737ejm.508.1600083275850; Mon, 14 Sep 2020 04:34:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600083275; cv=none; d=google.com; s=arc-20160816; b=aMABZb5vsk/JYXifkElHxO65U+0PRLd0YuCJVI5MtiAPpzqxs5UN43ijwrC4Ptv8Wx BXqELVB5LcpONYW1bN6/Uy+C1L1/Kc4MKeshsB8uCGtTHYHI0o4DzWv6qdrJr7gjdPJ1 VN/o65LEGHaMtsI//jJCCgVInFh5Kgi+wnRuVz9Kk0dz1ahzOdo0dnXrB4BEZbG5dDpQ joZ3MMF93JF98vOabfYx2JAJf18Mngavq00krnRfJLGMqdBxj28qRI7IC2f2OXOfUKdC O/3r7AQqMqM6GyAwcgVxSO5lDV9Prssd3ea/0KDkDcSspHLb8wyWaryykJY43sMHHAt9 KP/w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=X4FFoPCht9UaMtk6UlUUrOfzS+Poq/hwybaPrJLxODg=; b=zDWbivLoWhmUJGhXQ7Ri3rvZyH2b48d8CkagIOGg0c5oyKc+e3Lx8Yz5tLrJ5Glc4b 0w4ofhxEZpzWAOb5xVXj5Njl+M16vRgBvuhVZsl21qHhAOPc526l1Ix/VHCglqrhVk6H Ip+UN3b4B7aeMWnzvcxFUHADH+2N+byJ0JhwMuFhqHeOTrvJ231H2I+jk5XDYX4q1bIk i3h95UHdT6KA+w379trETFfLVo2f6wHoQ7ChRlp/tmMZP1jsqcxuBdCWxjiRL5JiOBJH tRLkl80cAi0F92uSBhnISMb+JxcBa4QFs4dyZfuLjei3VSoihtIofPbQw4ZqdU+zjz28 KlzA== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id c33si7549040edf.530.2020.09.14.04.34.11; Mon, 14 Sep 2020 04:34:35 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726121AbgINLdd (ORCPT + 99 others); Mon, 14 Sep 2020 07:33:33 -0400 Received: from foss.arm.com ([217.140.110.172]:34868 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726111AbgINLbR (ORCPT ); Mon, 14 Sep 2020 07:31:17 -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 199C6106F; Mon, 14 Sep 2020 04:31:17 -0700 (PDT) Received: from e107158-lin.cambridge.arm.com (e107158-lin.cambridge.arm.com [10.1.195.21]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 66C333F68F; Mon, 14 Sep 2020 04:31:15 -0700 (PDT) Date: Mon, 14 Sep 2020 12:31:13 +0100 From: Qais Yousef To: Valentin Schneider Cc: "Li, Aubrey" , Aubrey Li , mingo@redhat.com, peterz@infradead.org, juri.lelli@redhat.com, vincent.guittot@linaro.org, dietmar.eggemann@arm.com, rostedt@goodmis.org, bsegall@google.com, mgorman@suse.de, tim.c.chen@linux.intel.com, linux-kernel@vger.kernel.org Subject: Re: [RFC PATCH v1 1/1] sched/fair: select idle cpu from idle cpumask in sched domain Message-ID: <20200914113112.rmwsgjkudejestmc@e107158-lin.cambridge.arm.com> References: <20200910054203.525420-1-aubrey.li@intel.com> <20200910054203.525420-2-aubrey.li@intel.com> <20200911162853.xldy6fvvqph2lahj@e107158-lin.cambridge.arm.com> <3f1571ea-b74c-fc40-2696-39ef3fe8b968@linux.intel.com> <20200914110809.2nu7vt2s3lzlvxoz@e107158-lin.cambridge.arm.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: User-Agent: NeoMutt/20171215 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 09/14/20 12:26, Valentin Schneider wrote: > > On 14/09/20 12:08, Qais Yousef wrote: > > On 09/14/20 11:31, Valentin Schneider wrote: > >> > >> On 12/09/20 00:04, Li, Aubrey wrote: > >> >>> +++ b/include/linux/sched/topology.h > >> >>> @@ -65,8 +65,21 @@ struct sched_domain_shared { > >> >>> atomic_t ref; > >> >>> atomic_t nr_busy_cpus; > >> >>> int has_idle_cores; > >> >>> + /* > >> >>> + * Span of all idle CPUs in this domain. > >> >>> + * > >> >>> + * NOTE: this field is variable length. (Allocated dynamically > >> >>> + * by attaching extra space to the end of the structure, > >> >>> + * depending on how many CPUs the kernel has booted up with) > >> >>> + */ > >> >>> + unsigned long idle_cpus_span[]; > >> >> > >> >> Can't you use cpumask_var_t and zalloc_cpumask_var() instead? > >> > > >> > I can use the existing free code. Do we have a problem of this? > >> > > >> > >> Nah, flexible array members are the preferred approach here; this also > > > > Is this your opinion or a rule written somewhere I missed? > > I don't think there's a written rule, but AIUI it is preferred by at > least Peter: > > https://lore.kernel.org/linux-pm/20180612125930.GP12217@hirez.programming.kicks-ass.net/ > https://lore.kernel.org/lkml/20180619110734.GO2458@hirez.programming.kicks-ass.net/ > > And my opinion is that, if you can, having fewer separate allocation is better. +1 > > > > >> means we don't let CONFIG_CPUMASK_OFFSTACK dictate where this gets > >> allocated. > >> > >> See struct numa_group, struct sched_group, struct sched_domain, struct > >> em_perf_domain... > > > > struct root_domain, struct cpupri_vec, struct generic_pm_domain, > > struct irq_common_data.. > > > > Use cpumask_var_t. > > > > Both approach look correct to me, so no objection in principle. cpumask_var_t > > looks neater IMO and will be necessary once more than one cpumask are required > > in a struct. > > > > You're right in that cpumask_var_t becomes necessary when you need more > than one mask. For those that use it despite requiring only one mask > (cpupri stuff, struct nohz too), I'm not sure. I don't have a strong opinoin. cpumask_var_t is more readable and maintainble IMO. But it's not a big deal. Any form can be easily changed. Thanks -- Qais Yousef