cpu_stop: implement stop_cpu[s]()
commit1142d810298e694754498dbb4983fcb6cb7fd884
authorTejun Heo <tj@kernel.org>
Thu, 6 May 2010 16:49:20 +0000 (6 18:49 +0200)
committerTejun Heo <tj@kernel.org>
Thu, 6 May 2010 16:49:20 +0000 (6 18:49 +0200)
tree8c5d23b76f129e23d9d967182aa434795e44af5c
parent99bd5e2f245d8cd17d040c82d40becdb3efd9b69
cpu_stop: implement stop_cpu[s]()

Implement a simplistic per-cpu maximum priority cpu monopolization
mechanism.  A non-sleeping callback can be scheduled to run on one or
multiple cpus with maximum priority monopolozing those cpus.  This is
primarily to replace and unify RT workqueue usage in stop_machine and
scheduler migration_thread which currently is serving multiple
purposes.

Four functions are provided - stop_one_cpu(), stop_one_cpu_nowait(),
stop_cpus() and try_stop_cpus().

This is to allow clean sharing of resources among stop_cpu and all the
migration thread users.  One stopper thread per cpu is created which
is currently named "stopper/CPU".  This will eventually replace the
migration thread and take on its name.

* This facility was originally named cpuhog and lived in separate
  files but Peter Zijlstra nacked the name and thus got renamed to
  cpu_stop and moved into stop_machine.c.

* Better reporting of preemption leak as per Peter's suggestion.

Signed-off-by: Tejun Heo <tj@kernel.org>
Acked-by: Peter Zijlstra <peterz@infradead.org>
Cc: Oleg Nesterov <oleg@redhat.com>
Cc: Dimitri Sivanich <sivanich@sgi.com>
include/linux/stop_machine.h
kernel/stop_machine.c