From: Peter Zijlstra <peterz@infradead.org>
To: K Prateek Nayak <kprateek.nayak@amd.com>
Cc: John Stultz <jstultz@google.com>,
Joel Fernandes <joelagnelf@nvidia.com>,
Qais Yousef <qyousef@layalina.io>, Ingo Molnar <mingo@redhat.com>,
Juri Lelli <juri.lelli@redhat.com>,
Vincent Guittot <vincent.guittot@linaro.org>,
Dietmar Eggemann <dietmar.eggemann@arm.com>,
Valentin Schneider <vschneid@redhat.com>,
Steven Rostedt <rostedt@goodmis.org>,
Ben Segall <bsegall@google.com>,
Zimuzo Ezeozue <zezeozue@google.com>,
Will Deacon <will@kernel.org>, Waiman Long <longman@redhat.com>,
Boqun Feng <boqun.feng@gmail.com>,
"Paul E. McKenney" <paulmck@kernel.org>,
Metin Kaya <Metin.Kaya@arm.com>,
Xuewen Yan <xuewen.yan94@gmail.com>,
Thomas Gleixner <tglx@linutronix.de>,
Daniel Lezcano <daniel.lezcano@linaro.org>,
Suleiman Souhlal <suleiman@google.com>,
kuyo chang <kuyo.chang@mediatek.com>, hupu <hupu.gm@gmail.com>,
linux-kernel@vger.kernel.org, Mike Galbraith <efault@gmx.de>
Subject: Re: [PATCH 1/6] sched/proxy: Remove superfluous clear_task_blocked_in()
Date: Fri, 29 May 2026 10:50:53 +0200 [thread overview]
Message-ID: <20260529085053.GA3568911@noisy.programming.kicks-ass.net> (raw)
In-Reply-To: <20260529084712.GL343181@noisy.programming.kicks-ass.net>
On Fri, May 29, 2026 at 10:47:12AM +0200, Peter Zijlstra wrote:
> On Fri, May 29, 2026 at 12:15:09PM +0530, K Prateek Nayak wrote:
>
> > diff --git a/kernel/sched/core.c b/kernel/sched/core.c
> > index a125e65c35bb..fe903976fd09 100644
> > --- a/kernel/sched/core.c
> > +++ b/kernel/sched/core.c
> > @@ -3764,28 +3764,28 @@ static inline void proxy_reset_donor(struct rq *rq)
> > */
> > static inline bool proxy_needs_return(struct rq *rq, struct task_struct *p)
> > {
> > - if (!p->is_blocked)
> > - return false;
> > -
> > - /*
> > - * Typically per __set_task_cpu(), task_cpu(p) == p->wake_cpu.
> > - *
> > - * However, proxy_set_task_cpu() is such that it preserves the
> > - * original cpu in p->wake_cpu while migrating p for proxy reasons
> > - * (possibly outside of the allowed p->cpus_ptr).
> > - *
> > - * Furthermore, migration_cpu_stop() / __migrate_swap_task(), will
> > - * only set p->wake_cpu when !p->on_rq, and since here p->on_rq, this
> > - * will not apply. But if it did, this check is the safe way around
> > - * and would migrate.
> > - */
> > - if (task_cpu(p) == p->wake_cpu)
> > + if (!task_is_blocked(p))
> > return false;
> >
> > scoped_guard(raw_spinlock, &p->blocked_lock) {
> > /* Task is waking up; clear any blocked_on relationship */
> > __clear_task_blocked_on(p, NULL);
> >
> > + /*
> > + * Typically per __set_task_cpu(), task_cpu(p) == p->wake_cpu.
> > + *
> > + * However, proxy_set_task_cpu() is such that it preserves the
> > + * original cpu in p->wake_cpu while migrating p for proxy reasons
> > + * (possibly outside of the allowed p->cpus_ptr).
> > + *
> > + * Furthermore, migration_cpu_stop() / __migrate_swap_task(), will
> > + * only set p->wake_cpu when !p->on_rq, and since here p->on_rq, this
> > + * will not apply. But if it did, this check is the safe way around
> > + * and would migrate.
> > + */
> > + if (task_cpu(p) == p->wake_cpu)
> > + return false;
> > +
> > /* If already current, don't need to return migrate */
> > if (task_current(rq, p))
> > return false;
>
> Egads, this is terrible. This means all is_blocked tasks always end up
> taking blocked_lock.
>
> The other suggestion (in the other subthread) was to simply delay this
> patch until the end. That seems far more sensible.
>
> Anyway, let me go try and find your git tree and see what you ended up
> with.
Argh, github is such an absolute terrible piece of shit :-( It won't
even let me browse git trees because of rate-limiting or something
stupid -- I've done less than 10 clicks on the site and it says I hit a
limit and should wait and/or log in.
Fuckers.
next prev parent reply other threads:[~2026-05-29 8:51 UTC|newest]
Thread overview: 45+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-26 11:16 [PATCH 0/6] sched/proxy: doodles Peter Zijlstra
2026-05-26 11:16 ` [PATCH 1/6] sched/proxy: Remove superfluous clear_task_blocked_in() Peter Zijlstra
2026-05-26 23:39 ` John Stultz
2026-05-26 23:54 ` John Stultz
2026-05-27 8:59 ` Peter Zijlstra
2026-05-28 23:20 ` John Stultz
2026-05-29 6:45 ` K Prateek Nayak
2026-05-29 7:14 ` John Stultz
2026-05-29 8:24 ` K Prateek Nayak
2026-05-29 8:47 ` Peter Zijlstra
2026-05-29 8:50 ` Peter Zijlstra [this message]
2026-05-29 10:46 ` K Prateek Nayak
2026-05-30 2:56 ` John Stultz
2026-05-29 9:33 ` Peter Zijlstra
2026-05-29 6:48 ` John Stultz
2026-05-29 7:58 ` K Prateek Nayak
2026-05-29 10:06 ` Peter Zijlstra
2026-05-29 10:54 ` K Prateek Nayak
2026-06-04 18:45 ` [tip: sched/core] " tip-bot2 for Peter Zijlstra
2026-05-26 11:16 ` [PATCH 2/6] sched/proxy: Optimize try_to_wake_up() Peter Zijlstra
2026-05-27 1:56 ` John Stultz
2026-06-04 18:45 ` [tip: sched/core] " tip-bot2 for Peter Zijlstra
2026-05-26 11:16 ` [PATCH 3/6] sched: Be more strict about p->is_blocked Peter Zijlstra
2026-05-27 1:56 ` John Stultz
2026-06-04 18:45 ` [tip: sched/core] " tip-bot2 for Peter Zijlstra
2026-05-26 11:16 ` [PATCH 4/6] sched/proxy: Switch proxy to use p->is_blocked Peter Zijlstra
2026-05-26 14:57 ` Peter Zijlstra
2026-05-26 19:48 ` John Stultz
2026-05-27 2:25 ` John Stultz
2026-05-27 8:29 ` Peter Zijlstra
2026-06-04 18:45 ` [tip: sched/core] sched/proxy: Only return migrate when needed tip-bot2 for Peter Zijlstra
2026-06-04 18:45 ` [tip: sched/core] sched/proxy: Switch proxy to use p->is_blocked tip-bot2 for Peter Zijlstra
2026-05-26 11:16 ` [PATCH 5/6] sched/proxy: Remove PROXY_WAKING Peter Zijlstra
2026-06-01 10:54 ` Peter Zijlstra
2026-06-01 20:32 ` John Stultz
2026-06-02 5:22 ` K Prateek Nayak
2026-06-02 6:58 ` John Stultz
2026-06-02 10:02 ` Peter Zijlstra
2026-06-04 18:29 ` John Stultz
2026-06-04 18:41 ` Peter Zijlstra
2026-06-02 3:19 ` K Prateek Nayak
2026-06-04 18:45 ` [tip: sched/core] " tip-bot2 for K Prateek Nayak
2026-05-26 11:16 ` [PATCH 6/6] sched: Simplify ttwu_runnable() Peter Zijlstra
2026-06-04 18:45 ` [tip: sched/core] " tip-bot2 for Peter Zijlstra
2026-05-26 11:45 ` [PATCH 0/6] sched/proxy: doodles Peter Zijlstra
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=20260529085053.GA3568911@noisy.programming.kicks-ass.net \
--to=peterz@infradead.org \
--cc=Metin.Kaya@arm.com \
--cc=boqun.feng@gmail.com \
--cc=bsegall@google.com \
--cc=daniel.lezcano@linaro.org \
--cc=dietmar.eggemann@arm.com \
--cc=efault@gmx.de \
--cc=hupu.gm@gmail.com \
--cc=joelagnelf@nvidia.com \
--cc=jstultz@google.com \
--cc=juri.lelli@redhat.com \
--cc=kprateek.nayak@amd.com \
--cc=kuyo.chang@mediatek.com \
--cc=linux-kernel@vger.kernel.org \
--cc=longman@redhat.com \
--cc=mingo@redhat.com \
--cc=paulmck@kernel.org \
--cc=qyousef@layalina.io \
--cc=rostedt@goodmis.org \
--cc=suleiman@google.com \
--cc=tglx@linutronix.de \
--cc=vincent.guittot@linaro.org \
--cc=vschneid@redhat.com \
--cc=will@kernel.org \
--cc=xuewen.yan94@gmail.com \
--cc=zezeozue@google.com \
/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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.