doc: Add housekeeping documentation
Signed-off-by: Frederic Weisbecker <frederic@kernel.org> Acked-by: Waiman Long <longman@redhat.com> Cc: Marco Crivellari <marco.crivellari@suse.com> Cc: Michal Hocko <mhocko@suse.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Tejun Heo <tj@kernel.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Waiman Long <longman@redhat.com>
This commit is contained in:
parent
d279138a27
commit
fa39ec4f89
|
|
@ -0,0 +1,111 @@
|
||||||
|
======================================
|
||||||
|
Housekeeping
|
||||||
|
======================================
|
||||||
|
|
||||||
|
|
||||||
|
CPU Isolation moves away kernel work that may otherwise run on any CPU.
|
||||||
|
The purpose of its related features is to reduce the OS jitter that some
|
||||||
|
extreme workloads can't stand, such as in some DPDK usecases.
|
||||||
|
|
||||||
|
The kernel work moved away by CPU isolation is commonly described as
|
||||||
|
"housekeeping" because it includes ground work that performs cleanups,
|
||||||
|
statistics maintainance and actions relying on them, memory release,
|
||||||
|
various deferrals etc...
|
||||||
|
|
||||||
|
Sometimes housekeeping is just some unbound work (unbound workqueues,
|
||||||
|
unbound timers, ...) that gets easily assigned to non-isolated CPUs.
|
||||||
|
But sometimes housekeeping is tied to a specific CPU and requires
|
||||||
|
elaborated tricks to be offloaded to non-isolated CPUs (RCU_NOCB, remote
|
||||||
|
scheduler tick, etc...).
|
||||||
|
|
||||||
|
Thus, a housekeeping CPU can be considered as the reverse of an isolated
|
||||||
|
CPU. It is simply a CPU that can execute housekeeping work. There must
|
||||||
|
always be at least one online housekeeping CPU at any time. The CPUs that
|
||||||
|
are not isolated are automatically assigned as housekeeping.
|
||||||
|
|
||||||
|
Housekeeping is currently divided in four features described
|
||||||
|
by the ``enum hk_type type``:
|
||||||
|
|
||||||
|
1. HK_TYPE_DOMAIN matches the work moved away by scheduler domain
|
||||||
|
isolation performed through ``isolcpus=domain`` boot parameter or
|
||||||
|
isolated cpuset partitions in cgroup v2. This includes scheduler
|
||||||
|
load balancing, unbound workqueues and timers.
|
||||||
|
|
||||||
|
2. HK_TYPE_KERNEL_NOISE matches the work moved away by tick isolation
|
||||||
|
performed through ``nohz_full=`` or ``isolcpus=nohz`` boot
|
||||||
|
parameters. This includes remote scheduler tick, vmstat and lockup
|
||||||
|
watchdog.
|
||||||
|
|
||||||
|
3. HK_TYPE_MANAGED_IRQ matches the IRQ handlers moved away by managed
|
||||||
|
IRQ isolation performed through ``isolcpus=managed_irq``.
|
||||||
|
|
||||||
|
4. HK_TYPE_DOMAIN_BOOT matches the work moved away by scheduler domain
|
||||||
|
isolation performed through ``isolcpus=domain`` only. It is similar
|
||||||
|
to HK_TYPE_DOMAIN except it ignores the isolation performed by
|
||||||
|
cpusets.
|
||||||
|
|
||||||
|
|
||||||
|
Housekeeping cpumasks
|
||||||
|
=================================
|
||||||
|
|
||||||
|
Housekeeping cpumasks include the CPUs that can execute the work moved
|
||||||
|
away by the matching isolation feature. These cpumasks are returned by
|
||||||
|
the following function::
|
||||||
|
|
||||||
|
const struct cpumask *housekeeping_cpumask(enum hk_type type)
|
||||||
|
|
||||||
|
By default, if neither ``nohz_full=``, nor ``isolcpus``, nor cpuset's
|
||||||
|
isolated partitions are used, which covers most usecases, this function
|
||||||
|
returns the cpu_possible_mask.
|
||||||
|
|
||||||
|
Otherwise the function returns the cpumask complement of the isolation
|
||||||
|
feature. For example:
|
||||||
|
|
||||||
|
With isolcpus=domain,7 the following will return a mask with all possible
|
||||||
|
CPUs except 7::
|
||||||
|
|
||||||
|
housekeeping_cpumask(HK_TYPE_DOMAIN)
|
||||||
|
|
||||||
|
Similarly with nohz_full=5,6 the following will return a mask with all
|
||||||
|
possible CPUs except 5,6::
|
||||||
|
|
||||||
|
housekeeping_cpumask(HK_TYPE_KERNEL_NOISE)
|
||||||
|
|
||||||
|
|
||||||
|
Synchronization against cpusets
|
||||||
|
=================================
|
||||||
|
|
||||||
|
Cpuset can modify the HK_TYPE_DOMAIN housekeeping cpumask while creating,
|
||||||
|
modifying or deleting an isolated partition.
|
||||||
|
|
||||||
|
The users of HK_TYPE_DOMAIN cpumask must then make sure to synchronize
|
||||||
|
properly against cpuset in order to make sure that:
|
||||||
|
|
||||||
|
1. The cpumask snapshot stays coherent.
|
||||||
|
|
||||||
|
2. No housekeeping work is queued on a newly made isolated CPU.
|
||||||
|
|
||||||
|
3. Pending housekeeping work that was queued to a non isolated
|
||||||
|
CPU which just turned isolated through cpuset must be flushed
|
||||||
|
before the related created/modified isolated partition is made
|
||||||
|
available to userspace.
|
||||||
|
|
||||||
|
This synchronization is maintained by an RCU based scheme. The cpuset update
|
||||||
|
side waits for an RCU grace period after updating the HK_TYPE_DOMAIN
|
||||||
|
cpumask and before flushing pending works. On the read side, care must be
|
||||||
|
taken to gather the housekeeping target election and the work enqueue within
|
||||||
|
the same RCU read side critical section.
|
||||||
|
|
||||||
|
A typical layout example would look like this on the update side
|
||||||
|
(``housekeeping_update()``)::
|
||||||
|
|
||||||
|
rcu_assign_pointer(housekeeping_cpumasks[type], trial);
|
||||||
|
synchronize_rcu();
|
||||||
|
flush_workqueue(example_workqueue);
|
||||||
|
|
||||||
|
And then on the read side::
|
||||||
|
|
||||||
|
rcu_read_lock();
|
||||||
|
cpu = housekeeping_any_cpu(HK_TYPE_DOMAIN);
|
||||||
|
queue_work_on(cpu, example_workqueue, work);
|
||||||
|
rcu_read_unlock();
|
||||||
|
|
@ -25,6 +25,7 @@ it.
|
||||||
symbol-namespaces
|
symbol-namespaces
|
||||||
asm-annotations
|
asm-annotations
|
||||||
real-time/index
|
real-time/index
|
||||||
|
housekeeping.rst
|
||||||
|
|
||||||
Data structures and low-level utilities
|
Data structures and low-level utilities
|
||||||
=======================================
|
=======================================
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue