diff options
author | Tejun Heo <tj@kernel.org> | 2013-01-09 11:05:10 -0500 |
---|---|---|
committer | Tejun Heo <tj@kernel.org> | 2013-01-09 11:05:10 -0500 |
commit | 3c547865902e9fc30dc15941f326fd8039c6628d (patch) | |
tree | e86d926e86258cfc69d6665e28551fa14267634e /block/blk-cgroup.h | |
parent | 93e6d5d8f5c909479623c6ab4427f038c6c3f63f (diff) |
blkcg: make blkcg_gq's hierarchical
Currently a child blkg (blkcg_gq) can be created even if its parent
doesn't exist. ie. Given a blkg, it's not guaranteed that its
ancestors will exist. This makes it difficult to implement proper
hierarchy support for blkcg policies.
Always create blkgs recursively and make a child blkg hold a reference
to its parent. blkg->parent is added so that finding the parent is
easy. blkcg_parent() is also added in the process.
This change can be visible to userland. e.g. while issuing IO in a
nested cgroup didn't affect the ancestors at all, now it will
initialize all ancestor blkgs and zero stats for the request_queue
will always appear on them. While this is userland visible, this
shouldn't cause any functional difference.
Signed-off-by: Tejun Heo <tj@kernel.org>
Acked-by: Vivek Goyal <vgoyal@redhat.com>
Diffstat (limited to 'block/blk-cgroup.h')
-rw-r--r-- | block/blk-cgroup.h | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/block/blk-cgroup.h b/block/blk-cgroup.h index 24597309e23d..b26ed58899fe 100644 --- a/block/blk-cgroup.h +++ b/block/blk-cgroup.h | |||
@@ -94,8 +94,13 @@ struct blkcg_gq { | |||
94 | struct list_head q_node; | 94 | struct list_head q_node; |
95 | struct hlist_node blkcg_node; | 95 | struct hlist_node blkcg_node; |
96 | struct blkcg *blkcg; | 96 | struct blkcg *blkcg; |
97 | |||
98 | /* all non-root blkcg_gq's are guaranteed to have access to parent */ | ||
99 | struct blkcg_gq *parent; | ||
100 | |||
97 | /* request allocation list for this blkcg-q pair */ | 101 | /* request allocation list for this blkcg-q pair */ |
98 | struct request_list rl; | 102 | struct request_list rl; |
103 | |||
99 | /* reference count */ | 104 | /* reference count */ |
100 | int refcnt; | 105 | int refcnt; |
101 | 106 | ||
@@ -181,6 +186,19 @@ static inline struct blkcg *bio_blkcg(struct bio *bio) | |||
181 | } | 186 | } |
182 | 187 | ||
183 | /** | 188 | /** |
189 | * blkcg_parent - get the parent of a blkcg | ||
190 | * @blkcg: blkcg of interest | ||
191 | * | ||
192 | * Return the parent blkcg of @blkcg. Can be called anytime. | ||
193 | */ | ||
194 | static inline struct blkcg *blkcg_parent(struct blkcg *blkcg) | ||
195 | { | ||
196 | struct cgroup *pcg = blkcg->css.cgroup->parent; | ||
197 | |||
198 | return pcg ? cgroup_to_blkcg(pcg) : NULL; | ||
199 | } | ||
200 | |||
201 | /** | ||
184 | * blkg_to_pdata - get policy private data | 202 | * blkg_to_pdata - get policy private data |
185 | * @blkg: blkg of interest | 203 | * @blkg: blkg of interest |
186 | * @pol: policy of interest | 204 | * @pol: policy of interest |