All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] docs: scheduler: Convert schedutil.txt to ReST
@ 2022-03-11  3:04 Tang Yizhou
  2022-03-11 20:50 ` Jonathan Corbet
  0 siblings, 1 reply; 4+ messages in thread
From: Tang Yizhou @ 2022-03-11  3:04 UTC (permalink / raw)
  To: corbet, peterz, mingo
  Cc: linux-doc, zhengbin13, siyanteng, siyanteng01, tangyeechou, Tang Yizhou

All other scheduler documents have been converted to *.rst. Let's do
the same for schedutil.txt.

Signed-off-by: Tang Yizhou <tangyizhou@huawei.com>
---
 Documentation/scheduler/index.rst             |  1 +
 .../{schedutil.txt => schedutil.rst}          | 50 ++++++++++---------
 2 files changed, 28 insertions(+), 23 deletions(-)
 rename Documentation/scheduler/{schedutil.txt => schedutil.rst} (85%)

diff --git a/Documentation/scheduler/index.rst b/Documentation/scheduler/index.rst
index 30cca8a37b3b..b430d856056a 100644
--- a/Documentation/scheduler/index.rst
+++ b/Documentation/scheduler/index.rst
@@ -14,6 +14,7 @@ Linux Scheduler
     sched-domains
     sched-capacity
     sched-energy
+    schedutil
     sched-nice-design
     sched-rt-group
     sched-stats
diff --git a/Documentation/scheduler/schedutil.txt b/Documentation/scheduler/schedutil.rst
similarity index 85%
rename from Documentation/scheduler/schedutil.txt
rename to Documentation/scheduler/schedutil.rst
index 78f6b91e2291..bd96e08cdf88 100644
--- a/Documentation/scheduler/schedutil.txt
+++ b/Documentation/scheduler/schedutil.rst
@@ -1,11 +1,15 @@
+=========
+Schedutil
+=========
 
+.. note::
 
-NOTE; all this assumes a linear relation between frequency and work capacity,
-we know this is flawed, but it is the best workable approximation.
+   All this assumes a linear relation between frequency and work capacity,
+   we know this is flawed, but it is the best workable approximation.
 
 
 PELT (Per Entity Load Tracking)
--------------------------------
+===============================
 
 With PELT we track some metrics across the various scheduler entities, from
 individual tasks to task-group slices to CPU runqueues. As the basis for this
@@ -38,8 +42,8 @@ while 'runnable' will increase to reflect the amount of contention.
 For more detail see: kernel/sched/pelt.c
 
 
-Frequency- / CPU Invariance
----------------------------
+Frequency / CPU Invariance
+==========================
 
 Because consuming the CPU for 50% at 1GHz is not the same as consuming the CPU
 for 50% at 2GHz, nor is running 50% on a LITTLE CPU the same as running 50% on
@@ -47,23 +51,23 @@ a big CPU, we allow architectures to scale the time delta with two ratios, one
 Dynamic Voltage and Frequency Scaling (DVFS) ratio and one microarch ratio.
 
 For simple DVFS architectures (where software is in full control) we trivially
-compute the ratio as:
+compute the ratio as::
 
-	    f_cur
+            f_cur
   r_dvfs := -----
             f_max
 
 For more dynamic systems where the hardware is in control of DVFS we use
 hardware counters (Intel APERF/MPERF, ARMv8.4-AMU) to provide us this ratio.
-For Intel specifically, we use:
+For Intel specifically, we use::
 
-	   APERF
+           APERF
   f_cur := ----- * P0
-	   MPERF
+           MPERF
 
-	     4C-turbo;	if available and turbo enabled
-  f_max := { 1C-turbo;	if turbo enabled
-	     P0;	otherwise
+             4C-turbo;  if available and turbo enabled
+  f_max := { 1C-turbo;  if turbo enabled
+             P0;        otherwise
 
                     f_cur
   r_dvfs := min( 1, ----- )
@@ -87,7 +91,7 @@ For more detail see:
 
 
 UTIL_EST / UTIL_EST_FASTUP
---------------------------
+==========================
 
 Because periodic tasks have their averages decayed while they sleep, even
 though when running their expected utilization will be the same, they suffer a
@@ -106,7 +110,7 @@ For more detail see: kernel/sched/fair.c:util_est_dequeue()
 
 
 UCLAMP
-------
+======
 
 It is possible to set effective u_min and u_max clamps on each CFS or RT task;
 the runqueue keeps an max aggregate of these clamps for all running tasks.
@@ -115,7 +119,7 @@ For more detail see: include/uapi/linux/sched/types.h
 
 
 Schedutil / DVFS
-----------------
+================
 
 Every time the scheduler load tracking is updated (task wakeup, task
 migration, time progression) we call out to schedutil to update the hardware
@@ -123,19 +127,19 @@ DVFS state.
 
 The basis is the CPU runqueue's 'running' metric, which per the above it is
 the frequency invariant utilization estimate of the CPU. From this we compute
-a desired frequency like:
+a desired frequency like::
 
-             max( running, util_est );	if UTIL_EST
-  u_cfs := { running;			otherwise
+             max( running, util_est );  if UTIL_EST
+  u_cfs := { running;                   otherwise
 
-               clamp( u_cfs + u_rt , u_min, u_max );	if UCLAMP_TASK
-  u_clamp := { u_cfs + u_rt;				otherwise
+               clamp( u_cfs + u_rt, u_min, u_max );  if UCLAMP_TASK
+  u_clamp := { u_cfs + u_rt;                         otherwise
 
   u := u_clamp + u_irq + u_dl;		[approx. see source for more detail]
 
   f_des := min( f_max, 1.25 u * f_max )
 
-XXX IO-wait; when the update is due to a task wakeup from IO-completion we
+XXX IO-wait: when the update is due to a task wakeup from IO-completion we
 boost 'u' above.
 
 This frequency is then used to select a P-state/OPP or directly munged into a
@@ -153,7 +157,7 @@ For more information see: kernel/sched/cpufreq_schedutil.c
 
 
 NOTES
------
+=====
 
  - On low-load scenarios, where DVFS is most relevant, the 'running' numbers
    will closely reflect utilization.
-- 
2.17.1


^ permalink raw reply related	[flat|nested] 4+ messages in thread

* Re: [PATCH] docs: scheduler: Convert schedutil.txt to ReST
  2022-03-11  3:04 [PATCH] docs: scheduler: Convert schedutil.txt to ReST Tang Yizhou
@ 2022-03-11 20:50 ` Jonathan Corbet
  2022-03-12  6:29   ` Tang Yizhou
  2022-03-12 11:40   ` Peter Zijlstra
  0 siblings, 2 replies; 4+ messages in thread
From: Jonathan Corbet @ 2022-03-11 20:50 UTC (permalink / raw)
  To: Tang Yizhou, peterz, mingo
  Cc: linux-doc, zhengbin13, siyanteng, siyanteng01, tangyeechou, Tang Yizhou

Tang Yizhou <tangyizhou@huawei.com> writes:

> All other scheduler documents have been converted to *.rst. Let's do
> the same for schedutil.txt.
>
> Signed-off-by: Tang Yizhou <tangyizhou@huawei.com>
> ---
>  Documentation/scheduler/index.rst             |  1 +
>  .../{schedutil.txt => schedutil.rst}          | 50 ++++++++++---------
>  2 files changed, 28 insertions(+), 23 deletions(-)
>  rename Documentation/scheduler/{schedutil.txt => schedutil.rst} (85%)

I would like to see this change made so that this document can be built
with the rest of the kernel docs.  I will, however, defer to Peter and
will not accept this change over his objections.

That said, there is one other issue...
[...]

> --- a/Documentation/scheduler/schedutil.txt
> +++ b/Documentation/scheduler/schedutil.rst
> @@ -1,11 +1,15 @@
> +=========
> +Schedutil
> +=========
>  
> +.. note::
>  
> -NOTE; all this assumes a linear relation between frequency and work capacity,
> -we know this is flawed, but it is the best workable approximation.
> +   All this assumes a linear relation between frequency and work capacity,
> +   we know this is flawed, but it is the best workable approximation.
>  
>  
>  PELT (Per Entity Load Tracking)
> --------------------------------
> +===============================
>  
>  With PELT we track some metrics across the various scheduler entities, from
>  individual tasks to task-group slices to CPU runqueues. As the basis for this
> @@ -38,8 +42,8 @@ while 'runnable' will increase to reflect the amount of contention.
>  For more detail see: kernel/sched/pelt.c
>  
>  
> -Frequency- / CPU Invariance
> ----------------------------
> +Frequency / CPU Invariance
> +==========================
>  
>  Because consuming the CPU for 50% at 1GHz is not the same as consuming the CPU
>  for 50% at 2GHz, nor is running 50% on a LITTLE CPU the same as running 50% on
> @@ -47,23 +51,23 @@ a big CPU, we allow architectures to scale the time delta with two ratios, one
>  Dynamic Voltage and Frequency Scaling (DVFS) ratio and one microarch ratio.
>  
>  For simple DVFS architectures (where software is in full control) we trivially
> -compute the ratio as:
> +compute the ratio as::
>  
> -	    f_cur
> +            f_cur

You would appear to have done some space-to-tab conversions throughout
the file which muddies up the diff and makes it harder to see what you
have really changed.  Please redo the patch without unneeded white-space
changes.

Thanks,

jon

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] docs: scheduler: Convert schedutil.txt to ReST
  2022-03-11 20:50 ` Jonathan Corbet
@ 2022-03-12  6:29   ` Tang Yizhou
  2022-03-12 11:40   ` Peter Zijlstra
  1 sibling, 0 replies; 4+ messages in thread
From: Tang Yizhou @ 2022-03-12  6:29 UTC (permalink / raw)
  To: Jonathan Corbet, peterz, mingo
  Cc: linux-doc, zhengbin13, siyanteng, siyanteng01, tangyeechou

On 2022/3/12 4:50, Jonathan Corbet wrote:

> You would appear to have done some space-to-tab conversions throughout
> the file which muddies up the diff and makes it harder to see what you
> have really changed.  Please redo the patch without unneeded white-space
> changes.

I just find out these space-to-tab conversions are not necessary because
the rendered HTML texts have already been aligned.

Will remove them in the next version.

Regards,
Tang

^ permalink raw reply	[flat|nested] 4+ messages in thread

* Re: [PATCH] docs: scheduler: Convert schedutil.txt to ReST
  2022-03-11 20:50 ` Jonathan Corbet
  2022-03-12  6:29   ` Tang Yizhou
@ 2022-03-12 11:40   ` Peter Zijlstra
  1 sibling, 0 replies; 4+ messages in thread
From: Peter Zijlstra @ 2022-03-12 11:40 UTC (permalink / raw)
  To: Jonathan Corbet
  Cc: Tang Yizhou, mingo, linux-doc, zhengbin13, siyanteng,
	siyanteng01, tangyeechou

On Fri, Mar 11, 2022 at 01:50:15PM -0700, Jonathan Corbet wrote:
> Tang Yizhou <tangyizhou@huawei.com> writes:
> 
> > All other scheduler documents have been converted to *.rst. Let's do
> > the same for schedutil.txt.
> >
> > Signed-off-by: Tang Yizhou <tangyizhou@huawei.com>
> > ---
> >  Documentation/scheduler/index.rst             |  1 +
> >  .../{schedutil.txt => schedutil.rst}          | 50 ++++++++++---------
> >  2 files changed, 28 insertions(+), 23 deletions(-)
> >  rename Documentation/scheduler/{schedutil.txt => schedutil.rst} (85%)
> 
> I would like to see this change made so that this document can be built
> with the rest of the kernel docs.  I will, however, defer to Peter and
> will not accept this change over his objections.

As I'm sure you're aware, I'd *love* to convert the whole lot to plain
text again :-)

People, throughout the ages, have been able to read plain text, I don't
see why it should be made more difficult than that.

^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2022-03-12 11:40 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-03-11  3:04 [PATCH] docs: scheduler: Convert schedutil.txt to ReST Tang Yizhou
2022-03-11 20:50 ` Jonathan Corbet
2022-03-12  6:29   ` Tang Yizhou
2022-03-12 11:40   ` Peter Zijlstra

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.