diff options
author | Tejun Heo <tj@kernel.org> | 2012-03-05 16:15:20 -0500 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2012-03-06 15:27:23 -0500 |
commit | e8989fae38d9831c72b20375a206a919ca468c52 (patch) | |
tree | 2eeb1320e526cd0ba187465c0e6e19799dc1b956 /block/elevator.c | |
parent | 03aa264ac15637b6f98374270bcdf31400965505 (diff) |
blkcg: unify blkg's for blkcg policies
Currently, blkg is per cgroup-queue-policy combination. This is
unnatural and leads to various convolutions in partially used
duplicate fields in blkg, config / stat access, and general management
of blkgs.
This patch make blkg's per cgroup-queue and let them serve all
policies. blkgs are now created and destroyed by blkcg core proper.
This will allow further consolidation of common management logic into
blkcg core and API with better defined semantics and layering.
As a transitional step to untangle blkg management, elvswitch and
policy [de]registration, all blkgs except the root blkg are being shot
down during elvswitch and bypass. This patch adds blkg_root_update()
to update root blkg in place on policy change. This is hacky and racy
but should be good enough as interim step until we get locking
simplified and switch over to proper in-place update for all blkgs.
-v2: Root blkgs need to be updated on elvswitch too and blkg_alloc()
comment wasn't updated according to the function change. Fixed.
Both pointed out by Vivek.
-v3: v2 updated blkg_destroy_all() to invoke update_root_blkg_pd() for
all policies. This freed root pd during elvswitch before the
last queue finished exiting and led to oops. Directly invoke
update_root_blkg_pd() only on BLKIO_POLICY_PROP from
cfq_exit_queue(). This also is closer to what will be done with
proper in-place blkg update. Reported by Vivek.
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 'block/elevator.c')
-rw-r--r-- | block/elevator.c | 5 |
1 files changed, 2 insertions, 3 deletions
diff --git a/block/elevator.c b/block/elevator.c index d4d39dab841a..451654fadab0 100644 --- a/block/elevator.c +++ b/block/elevator.c | |||
@@ -876,7 +876,7 @@ static int elevator_switch(struct request_queue *q, struct elevator_type *new_e) | |||
876 | { | 876 | { |
877 | struct elevator_queue *old = q->elevator; | 877 | struct elevator_queue *old = q->elevator; |
878 | bool registered = old->registered; | 878 | bool registered = old->registered; |
879 | int i, err; | 879 | int err; |
880 | 880 | ||
881 | /* | 881 | /* |
882 | * Turn on BYPASS and drain all requests w/ elevator private data. | 882 | * Turn on BYPASS and drain all requests w/ elevator private data. |
@@ -895,8 +895,7 @@ static int elevator_switch(struct request_queue *q, struct elevator_type *new_e) | |||
895 | ioc_clear_queue(q); | 895 | ioc_clear_queue(q); |
896 | spin_unlock_irq(q->queue_lock); | 896 | spin_unlock_irq(q->queue_lock); |
897 | 897 | ||
898 | for (i = 0; i < BLKIO_NR_POLICIES; i++) | 898 | blkg_destroy_all(q, false); |
899 | blkg_destroy_all(q, i, false); | ||
900 | 899 | ||
901 | /* allocate, init and register new elevator */ | 900 | /* allocate, init and register new elevator */ |
902 | err = -ENOMEM; | 901 | err = -ENOMEM; |