]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
sched: Be more strict about p->is_blocked
authorPeter Zijlstra <peterz@infradead.org>
Tue, 26 May 2026 09:32:34 +0000 (11:32 +0200)
committerPeter Zijlstra <peterz@infradead.org>
Tue, 2 Jun 2026 10:26:08 +0000 (12:26 +0200)
Upon entry to try_to_block_task(), p->is_blocked should be false. After all,
the prior wakeup would have made it so per ttwu_do_wakeup().

Ensure this is the case, rather than clearing it in the path that doesn't set
it.

Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Acked-by: John Stultz <jstultz@google.com>
Link: https://patch.msgid.link/20260526113322.364017314%40infradead.org
kernel/sched/core.c

index a06d5a57adc858e2f477214f1cbba897fbfa7ec9..8b7eb126c254d803c04a1d3e4b7c690c3bddc91d 100644 (file)
@@ -6676,8 +6676,9 @@ static bool try_to_block_task(struct rq *rq, struct task_struct *p,
 {
        unsigned long task_state = *task_state_p;
 
+       WARN_ON_ONCE(p->is_blocked);
+
        if (signal_pending_state(task_state, p)) {
-               p->is_blocked = 0;
                WRITE_ONCE(p->__state, TASK_RUNNING);
                *task_state_p = TASK_RUNNING;
                clear_task_blocked_on(p, NULL);