From: Youssef Esmat Date: Mon, 27 May 2024 12:06:49 +0000 (+0200) Subject: sched/core: Clear prev->dl_server in CFS pick fast path X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=a741b82423f41501e301eb6f9820b45ca202e877;p=users%2Fjedix%2Flinux-maple.git sched/core: Clear prev->dl_server in CFS pick fast path In case the previous pick was a DL server pick, ->dl_server might be set. Clear it in the fast path as well. Fixes: 63ba8422f876 ("sched/deadline: Introduce deadline servers") Signed-off-by: Youssef Esmat Signed-off-by: Daniel Bristot de Oliveira Signed-off-by: Peter Zijlstra (Intel) Tested-by: Juri Lelli Cc: stable@vger.kernel.org Link: https://lore.kernel.org/r/7f7381ccba09efcb4a1c1ff808ed58385eccc222.1716811044.git.bristot@kernel.org --- diff --git a/kernel/sched/core.c b/kernel/sched/core.c index e61da3b88be31..1074ae8044808 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -5839,6 +5839,13 @@ __pick_next_task(struct rq *rq, struct task_struct *prev, struct rq_flags *rf) p = pick_next_task_idle(rq); } + /* + * This is a normal CFS pick, but the previous could be a DL pick. + * Clear it as previous is no longer picked. + */ + if (prev->dl_server) + prev->dl_server = NULL; + /* * This is the fast path; it cannot be a DL server pick; * therefore even if @p == @prev, ->dl_server must be NULL.