sched/dlserver: Fix dlserver time accounting

dlserver time is accounted when:
 - dlserver is active and the dlserver proxies the cfs task.
 - dlserver is active but deferred and cfs task runs after being picked
   through the normal fair class pick.

dl_server_update is called in two places to make sure that both the
above times are accounted for. But it doesn't check if dlserver is
active or not. Now that we have this dl_server_active flag, we can
consolidate dl_server_update into one place and all we need to check is
whether dlserver is active or not. When dlserver is active there is only
two possible conditions:
 - dlserver is deferred.
 - cfs task is running on behalf of dlserver.

Fixes: a110a81c52 ("sched/deadline: Deferrable dl server")
Signed-off-by: "Vineeth Pillai (Google)" <vineeth@bitbyteword.org>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Tested-by: Marcel Ziswiler <marcel.ziswiler@codethink.co.uk> # ROCK 5B
Link: https://lore.kernel.org/r/20241213032244.877029-2-vineeth@bitbyteword.org
This commit is contained in:
Vineeth Pillai (Google) 2024-12-12 22:22:37 -05:00 committed by Peter Zijlstra
parent b53127db1d
commit c7f7e9c731

View File

@ -1159,8 +1159,6 @@ static inline void update_curr_task(struct task_struct *p, s64 delta_exec)
trace_sched_stat_runtime(p, delta_exec); trace_sched_stat_runtime(p, delta_exec);
account_group_exec_runtime(p, delta_exec); account_group_exec_runtime(p, delta_exec);
cgroup_account_cputime(p, delta_exec); cgroup_account_cputime(p, delta_exec);
if (p->dl_server)
dl_server_update(p->dl_server, delta_exec);
} }
static inline bool did_preempt_short(struct cfs_rq *cfs_rq, struct sched_entity *curr) static inline bool did_preempt_short(struct cfs_rq *cfs_rq, struct sched_entity *curr)
@ -1237,11 +1235,16 @@ static void update_curr(struct cfs_rq *cfs_rq)
update_curr_task(p, delta_exec); update_curr_task(p, delta_exec);
/* /*
* Any fair task that runs outside of fair_server should * If the fair_server is active, we need to account for the
* account against fair_server such that it can account for * fair_server time whether or not the task is running on
* this time and possibly avoid running this period. * behalf of fair_server or not:
* - If the task is running on behalf of fair_server, we need
* to limit its time based on the assigned runtime.
* - Fair task that runs outside of fair_server should account
* against fair_server such that it can account for this time
* and possibly avoid running this period.
*/ */
if (p->dl_server != &rq->fair_server) if (dl_server_active(&rq->fair_server))
dl_server_update(&rq->fair_server, delta_exec); dl_server_update(&rq->fair_server, delta_exec);
} }