On Thu, 25 Jun 2020 at 12:42, Holger Hoffstätte
<hol...@applied-asynchrony.com> wrote:
>
> On 2020-06-25 11:56, Vincent Guittot wrote:
> > On Thu, 25 Jun 2020 at 11:24, Holger Hoffstätte
> > <hol...@applied-asynchrony.com> wrote:
> >>
> >> On 2020-06-24 17:44, Vincent Guittot wrote:
> >>> Some performance regression on reaim benchmark have been raised with
> >>>     commit 070f5e860ee2 ("sched/fair: Take into account runnable_avg to 
> >>> classify group")
> >>>
> >>> The problem comes from the init value of runnable_avg which is initialized
> >>> with max value. This can be a problem if the newly forked task is finally
> >>> a short task because the group of CPUs is wrongly set to overloaded and
> >>> tasks are pulled less agressively.
> >>>
> >>> Set initial value of runnable_avg equals to util_avg to reflect that there
> >>> is no waiting time so far.
> >>>
> >>> Fixes: 070f5e860ee2 ("sched/fair: Take into account runnable_avg to 
> >>> classify group")
> >>> Reported-by: kernel test robot <rong.a.c...@intel.com>
> >>> Signed-off-by: Vincent Guittot <vincent.guit...@linaro.org>
> >>> ---
> >>>    kernel/sched/fair.c | 2 +-
> >>>    1 file changed, 1 insertion(+), 1 deletion(-)
> >>>
> >>> diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c
> >>> index 0424a0af5f87..45e467bf42fc 100644
> >>> --- a/kernel/sched/fair.c
> >>> +++ b/kernel/sched/fair.c
> >>> @@ -806,7 +806,7 @@ void post_init_entity_util_avg(struct task_struct *p)
> >>>                }
> >>>        }
> >>>
> >>> -     sa->runnable_avg = cpu_scale;
> >>> +     sa->runnable_avg = sa->util_avg;
> >>>
> >>>        if (p->sched_class != &fair_sched_class) {
> >>>                /*
> >>>
> >>
> >> Something is wrong here. I woke up my machine from suspend-to-RAM this 
> >> morning
> >> and saw that a completely idle machine had a loadavg of ~7. According to my
> >
> > Just to make sure: Are you speaking about loadavg that is output by
> > /proc/loadavg or load_avg which is the PELT load ?
>
> /proc/loadavg
>
> >> monitoring system this happened to be the loadavg right before I suspended.
> >> I've reverted this, rebooted, created a loadavg >0, suspended and after 
> >> wake up
> >> loadavg again correctly ranges between 0 and whatever, as expected.
> >
> > I'm not sure to catch why ~7 is bad compared to correctly ranges
> > between 0 and whatever. Isn't ~7 part of the whatever ?
>
> After wakeup the _baseline_ for loadavg seemed to be the last value before 
> suspend,
> not 0. The 7 then was the base loadavg for a _mostly idle machine_ (just 
> reading
> mail etc.), i.e. it never went below said baseline again, no matter the
> _actual_ load.
>
> Here's an image: https://imgur.com/a/kd2stqO
>
> Before 02:00 last night the load was ~7 (compiled something), then all 
> processes
> were terminated and the machine was suspended. After wakeup the machine was 
> mostly
> idle (9am..11am), yet measured loadavg continued with the same value as 
> before.
> I didn't notice this right away since my CPU meter on the desktop didn't show 
> any
> *actual* activity (because there was none). The spike at ~11am is the 
> revert/reboot.

you have reverted only this patch ?

TBH, there is no link between these 2 metrics and I don't see how the
init value of runnable_avg can impact loadavg. As explained, loadavg
is doing a snapshot of nr_running every 5 seconds whereas the impact
of changing this init value will have disappeared in far less than
300ms most of the time.

Let me try to reproduce this on my system


> After that loadavg became normal again, i.e. representative of the actual 
> load,
> even after suspend/resume cycles.
> I suspend/resume every night and the only thing that changed recently was this
> patch, so.. :)
>
> -h

Reply via email to