[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20201123145128.GS3021@hirez.programming.kicks-ass.net>
Date:   Mon, 23 Nov 2020 15:51:28 +0100
From:   Peter Zijlstra <peterz@...radead.org>
To:     Dietmar Eggemann <dietmar.eggemann@....com>
Cc:     "Rafael J. Wysocki" <rjw@...ysocki.net>,
        Ingo Molnar <mingo@...nel.org>,
        Thomas Gleixner <tglx@...utronix.de>,
        Vincent Guittot <vincent.guittot@...aro.org>,
        Morten Rasmussen <morten.rasmussen@....com>,
        patrick.bellasi@...bug.net, lenb@...nel.org,
        linux-kernel@...r.kernel.org, valentin.schneider@....com,
        ionela.voinescu@....com, qperret@...gle.com,
        viresh.kumar@...aro.org
Subject: Re: [RFC] Documentation/scheduler/schedutil.txt
On Mon, Nov 23, 2020 at 10:26:13AM +0100, Dietmar Eggemann wrote:
> On 20/11/2020 08:55, Peter Zijlstra wrote:
> 
> [...]
> 
> > PELT (Per Entity Load Tracking)
> > -------------------------------
> 
> [...]
> 
> > Using this we track 2 key metrics: 'running' and 'runnable'. 'Running'
> > reflects the time an entity spends on the CPU, while 'runnable' reflects the
> > time an entity spends on the runqueue. When there is only a single task these
> > two metrics are the same, but once there is contention for the CPU 'running'
> > will decrease to reflect the fraction of time each task spends on the CPU
> > while 'runnable' will increase to reflect the amount of contention.
> 
> People might find it confusing to map 'running and 'runnable' into the 3
> PELT signals (load_avg, runnable_avg and util_avg) being used in the
> scheduler ... with load_avg being 'runnable' and 'weight' based.
Yeah, but that's for another document, I suppose. much of pelt.c uses
runnable. Also, the comment that goes with struct sched_avg should
explain.
> > For more detail see: kernel/sched/pelt.c
> > 
> > 
> > Frequency- / Heterogeneous Invariance
> > -------------------------------------
> 
> We call 'Heterogeneous Invariance' CPU invariance in chapter 2.3
> Documentation/scheduler/sched-capacity.rst.
> 
> [...]
Fair enough; I've renamed it to match.
> > For more detail see:
> > 
> >  - kernel/sched/pelt.h:update_rq_clock_pelt()
> >  - arch/x86/kernel/smpboot.c:"APERF/MPERF frequency ratio computation."
> 
> drivers/base/arch_topology.c:"f_cur/f_max ratio computation".
I can't seem to find that in any tree near me (I tried tip/master and
next/master)
> > UTIL_EST / UTIL_EST_FASTUP
> > --------------------------
> 
> [...]
> 
> >   util_est := \Sum_t max( t_running, t_util_est_ewma )
> > 
> > For more detail see: kernel/sched/fair.h:util_est_dequeue()
> 
> s/fair.h/fair.c
> 
> > UCLAMP
> > ------
> > 
> > It is possible to set effective u_min and u_max clamps on each task; the
> 
> s/on each task/on each CFS or RT task
Thanks!
Powered by blists - more mailing lists
 
