From: Valentin Schneider <valentin.schneider@arm.com>
To: Dietmar Eggemann <dietmar.eggemann@arm.com>,
linux-kernel@vger.kernel.org, cgroups@vger.kernel.org
Cc: lizefan@huawei.com, tj@kernel.org, hannes@cmpxchg.org,
mingo@kernel.org, peterz@infradead.org,
vincent.guittot@linaro.org, morten.rasmussen@arm.com,
qperret@google.com, stable@vger.kernel.org
Subject: Re: [PATCH v3 1/2] sched/topology: Don't try to build empty sched domains
Date: Tue, 22 Oct 2019 13:46:08 +0100 [thread overview]
Message-ID: <b38c30cd-f990-dd98-b414-c284f8f32cfd@arm.com> (raw)
In-Reply-To: <20dc939f-4102-334e-5fde-a442ee7eaa5e@arm.com>
On 22/10/2019 12:43, Dietmar Eggemann wrote:
> First I thought we can do with a little less drama by only preventing
> arch_scale_cpu_capacity() from consuming >= nr_cpu_ids.
>
> @@ -1894,6 +1894,9 @@ static struct sched_domain_topology_level
> struct sched_domain_topology_level *tl, *asym_tl = NULL;
> unsigned long cap;
>
> + if (cpumask_empty(cpu_map))
> + return NULL;
> +
>
> Until I tried to hp'ed in CPU4 after CPU4/5 had been hp'ed out (your
> example further below) and I got another:
>
> [ 68.014564] Unable to handle kernel paging request at virtual address
> fffe8009903d8ee0
> ...
> [ 68.191293] Call trace:
> [ 68.193712] partition_sched_domains_locked+0x1a4/0x4a0
> [ 68.198882] rebuild_sched_domains_locked+0x4d0/0x7b0
> [ 68.203880] rebuild_sched_domains+0x24/0x40
> [ 68.208104] cpuset_hotplug_workfn+0xe0/0x5f8
> ...
>
> @@ -2213,6 +2216,11 @@ void partition_sched_domains_locked(int
> ndoms_new, cpumask_var_t doms_new[],
> * will be recomputed in function
> * update_tasks_root_domain().
> */
> + if (cpumask_empty(doms_cur[i]))
> + printk("doms_cur[%d] empty\n", i);
> +
> rd = cpu_rq(cpumask_any(doms_cur[i]))->rd;
>
> doms_cur[i] is empty when hp'ing in CPU4 again.
>
> Your patch fixes this as well.
>
Thanks for giving it a spin!
> Might be worth noting that this is not only about asym CPU capacity
> handling but missing checks after cpumask operations in case the cpuset
> is empty.
Aye, we end up saving whatever we're given (doms_cur = doms_new at the end
of the rebuild). As you pointed out this is also an issue for the operation
done by
f9a25f776d78 ("cpusets: Rebuild root domain deadline accounting information")
but it has been introduced after the asymmetry check, hence why I'm tagging
the latter for stable.
next prev parent reply other threads:[~2019-10-22 12:46 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-10-15 15:42 [PATCH v3 0/2] sched/topology: Asymmetric topologies fixes Valentin Schneider
2019-10-15 15:42 ` [PATCH v3 1/2] sched/topology: Don't try to build empty sched domains Valentin Schneider
2019-10-22 11:43 ` Dietmar Eggemann
2019-10-22 12:46 ` Valentin Schneider [this message]
2019-10-23 11:46 ` Dietmar Eggemann
2019-10-23 14:12 ` Valentin Schneider
2019-10-15 15:42 ` [PATCH v3 2/2] sched/topology: Allow sched_asym_cpucapacity to be disabled Valentin Schneider
2019-10-23 8:45 ` Dietmar Eggemann
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=b38c30cd-f990-dd98-b414-c284f8f32cfd@arm.com \
--to=valentin.schneider@arm.com \
--cc=cgroups@vger.kernel.org \
--cc=dietmar.eggemann@arm.com \
--cc=hannes@cmpxchg.org \
--cc=linux-kernel@vger.kernel.org \
--cc=lizefan@huawei.com \
--cc=mingo@kernel.org \
--cc=morten.rasmussen@arm.com \
--cc=peterz@infradead.org \
--cc=qperret@google.com \
--cc=stable@vger.kernel.org \
--cc=tj@kernel.org \
--cc=vincent.guittot@linaro.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox