summaryrefslogtreecommitdiffstats
path: root/include/trace
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2013-01-24 20:01:33 +0100
committerTejun Heo <tj@kernel.org>2013-01-24 20:01:33 +0100
commitc9e7cf273fa1876dee8effdb201a6f65eefab3a7 (patch)
treefab0d36f4cd595d1d4bc9fb091d323ea66a692e1 /include/trace
parentworkqueue: record pool ID instead of CPU in work->data when off-queue (diff)
downloadlinux-c9e7cf273fa1876dee8effdb201a6f65eefab3a7.tar.xz
linux-c9e7cf273fa1876dee8effdb201a6f65eefab3a7.zip
workqueue: move busy_hash from global_cwq to worker_pool
There's no functional necessity for the two pools on the same CPU to share the busy hash table. It's also likely to be a bottleneck when implementing pools with user-specified attributes. This patch makes busy_hash per-pool. The conversion is mostly straight-forward. Changes worth noting are, * Large block of changes in rebind_workers() is moving the block inside for_each_worker_pool() as now there are separate hash tables for each pool. This changes the order of operations but doesn't break anything. * Thre for_each_worker_pool() loops in gcwq_unbind_fn() are combined into one. This again changes the order of operaitons but doesn't break anything. This is part of an effort to remove global_cwq and make worker_pool the top level abstraction, which in turn will help implementing worker pools with user-specified attributes. Signed-off-by: Tejun Heo <tj@kernel.org> Reviewed-by: Lai Jiangshan <laijs@cn.fujitsu.com>
Diffstat (limited to 'include/trace')
0 files changed, 0 insertions, 0 deletions