diff options
author | Tejun Heo <tj@kernel.org> | 2012-03-05 16:15:19 -0500 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2012-03-06 15:27:23 -0500 |
commit | 03aa264ac15637b6f98374270bcdf31400965505 (patch) | |
tree | 6fa9ca54d3f775fba19123790f6655158034a1d8 /include/linux/blkdev.h | |
parent | 4eef3049986e8397d5003916aed8cad6567a5e02 (diff) |
blkcg: let blkcg core manage per-queue blkg list and counter
With the previous patch to move blkg list heads and counters to
request_queue and blkg, logic to manage them in both policies are
almost identical and can be moved to blkcg core.
This patch moves blkg link logic into blkg_lookup_create(), implements
common blkg unlink code in blkg_destroy(), and updates
blkg_destory_all() so that it's policy specific and can skip root
group. The updated blkg_destroy_all() is now used to both clear queue
for bypassing and elv switching, and release all blkgs on q exit.
This patch introduces a race window where policy [de]registration may
race against queue blkg clearing. This can only be a problem on cfq
unload and shouldn't be a real problem in practice (and we have many
other places where this race already exists). Future patches will
remove these unlikely races.
Signed-off-by: Tejun Heo <tj@kernel.org>
Cc: Vivek Goyal <vgoyal@redhat.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'include/linux/blkdev.h')
-rw-r--r-- | include/linux/blkdev.h | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/include/linux/blkdev.h b/include/linux/blkdev.h index f4e35edea70f..b4d1d4bfc168 100644 --- a/include/linux/blkdev.h +++ b/include/linux/blkdev.h | |||
@@ -364,8 +364,8 @@ struct request_queue { | |||
364 | struct list_head icq_list; | 364 | struct list_head icq_list; |
365 | #ifdef CONFIG_BLK_CGROUP | 365 | #ifdef CONFIG_BLK_CGROUP |
366 | /* XXX: array size hardcoded to avoid include dependency (temporary) */ | 366 | /* XXX: array size hardcoded to avoid include dependency (temporary) */ |
367 | struct list_head blkg_list[2]; | 367 | struct list_head blkg_list; |
368 | int nr_blkgs[2]; | 368 | int nr_blkgs; |
369 | #endif | 369 | #endif |
370 | 370 | ||
371 | struct queue_limits limits; | 371 | struct queue_limits limits; |