On Thu, Nov 06, 2025 at 08:13:39AM +0100, Juri Lelli wrote:
> Hi,
> 
> On 29/10/25 20:08, Andrea Righi wrote:
> > From: Joel Fernandes <[email protected]>
> > 
> > Currently the DL server interface for applying parameters checks
> > CFS-internals to identify if the server is active. This is error-prone
> > and makes it difficult when adding new servers in the future.
> > 
> > Fix it, by using dl_server_active() which is also used by the DL server
> > code to determine if the DL server was started.
> > 
> > Acked-by: Tejun Heo <[email protected]>
> > Reviewed-by: Juri Lelli <[email protected]>
> > Reviewed-by: Andrea Righi <[email protected]>
> > Signed-off-by: Joel Fernandes <[email protected]>
> > ---
> >  kernel/sched/debug.c | 11 ++++++++---
> >  1 file changed, 8 insertions(+), 3 deletions(-)
> > 
> > diff --git a/kernel/sched/debug.c b/kernel/sched/debug.c
> > index 6cf9be6eea49a..e71f6618c1a6a 100644
> > --- a/kernel/sched/debug.c
> > +++ b/kernel/sched/debug.c
> > @@ -354,6 +354,8 @@ static ssize_t sched_fair_server_write(struct file 
> > *filp, const char __user *ubu
> >             return err;
> >  
> >     scoped_guard (rq_lock_irqsave, rq) {
> > +           bool is_active;
> > +
> >             runtime  = rq->fair_server.dl_runtime;
> >             period = rq->fair_server.dl_period;
> >  
> > @@ -376,8 +378,11 @@ static ssize_t sched_fair_server_write(struct file 
> > *filp, const char __user *ubu
> >                     return  -EINVAL;
> >             }
> >  
> > -           update_rq_clock(rq);
> > -           dl_server_stop(&rq->fair_server);
> > +           is_active = dl_server_active(&rq->fair_server);
> > +           if (is_active) {
> > +                   update_rq_clock(rq);
> > +                   dl_server_stop(&rq->fair_server);
> > +           }
> >  
> >             retval = dl_server_apply_params(&rq->fair_server, runtime, 
> > period, 0);
> >  
> > @@ -385,7 +390,7 @@ static ssize_t sched_fair_server_write(struct file 
> > *filp, const char __user *ubu
> >                     printk_deferred("Fair server disabled in CPU %d, system 
> > may crash due to starvation.\n",
> >                                     cpu_of(rq));
> >  
> > -           if (rq->cfs.h_nr_queued)
> > +           if (is_active)
> >                     dl_server_start(&rq->fair_server);
> 
> Something that I noticed while reviewing this series is that we still
> start back a server even if the user put its runtime to zero (disabling
> it) and I don't think we want to do that. It's not of course related to
> this change or this series per-se, but something we probably want to fix
> independently.

Should we just call dl_server_remove_params() when runtime is zero?

Thanks,
-Andrea

Reply via email to