Commit ce5f4fc8 authored by Paul E. McKenney's avatar Paul E. McKenney

nohz_full: Document additional restrictions

This commit calls out the potential for slowing the tick even when there
are multiple runnable processes per CPU,  It also points out that current
mainlined version keeps the tick going on at least one CPU even when all
CPUs are otherwise idle.  Finally, it notes the need for a 1-HZ tick in
order to calculate CPU load, maintain sched average, compute CFS entity
vruntime, compute avenrun, and carry out load balancing.
Signed-off-by: default avatarPaul E. McKenney <paulmck@linux.vnet.ibm.com>
Reviewed-by: default avatarJosh Triplett <josh@joshtriplett.org>
parent 295fde89
...@@ -278,6 +278,11 @@ o Adaptive-ticks does not do anything unless there is only one ...@@ -278,6 +278,11 @@ o Adaptive-ticks does not do anything unless there is only one
single runnable SCHED_FIFO task and multiple runnable SCHED_OTHER single runnable SCHED_FIFO task and multiple runnable SCHED_OTHER
tasks, even though these interrupts are unnecessary. tasks, even though these interrupts are unnecessary.
And even when there are multiple runnable tasks on a given CPU,
there is little point in interrupting that CPU until the current
running task's timeslice expires, which is almost always way
longer than the time of the next scheduling-clock interrupt.
Better handling of these sorts of situations is future work. Better handling of these sorts of situations is future work.
o A reboot is required to reconfigure both adaptive idle and RCU o A reboot is required to reconfigure both adaptive idle and RCU
...@@ -308,6 +313,16 @@ o Unless all CPUs are idle, at least one CPU must keep the ...@@ -308,6 +313,16 @@ o Unless all CPUs are idle, at least one CPU must keep the
scheduling-clock interrupt going in order to support accurate scheduling-clock interrupt going in order to support accurate
timekeeping. timekeeping.
o If there are adaptive-ticks CPUs, there will be at least one o If there might potentially be some adaptive-ticks CPUs, there
CPU keeping the scheduling-clock interrupt going, even if all will be at least one CPU keeping the scheduling-clock interrupt
CPUs are otherwise idle. going, even if all CPUs are otherwise idle.
Better handling of this situation is ongoing work.
o Some process-handling operations still require the occasional
scheduling-clock tick. These operations include calculating CPU
load, maintaining sched average, computing CFS entity vruntime,
computing avenrun, and carrying out load balancing. They are
currently accommodated by scheduling-clock tick every second
or so. On-going work will eliminate the need even for these
infrequent scheduling-clock ticks.
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment