diff options
-rw-r--r-- | block/blk-throttle.c | 35 |
1 files changed, 23 insertions, 12 deletions
diff --git a/block/blk-throttle.c b/block/blk-throttle.c index 68f2ac3f3b07..97ea7f82477d 100644 --- a/block/blk-throttle.c +++ b/block/blk-throttle.c | |||
@@ -188,16 +188,34 @@ throtl_add_group_to_td_list(struct throtl_data *td, struct throtl_grp *tg) | |||
188 | td->nr_undestroyed_grps++; | 188 | td->nr_undestroyed_grps++; |
189 | } | 189 | } |
190 | 190 | ||
191 | static void throtl_init_add_tg_lists(struct throtl_data *td, | 191 | static void |
192 | struct throtl_grp *tg, struct blkio_cgroup *blkcg) | 192 | __throtl_tg_fill_dev_details(struct throtl_data *td, struct throtl_grp *tg) |
193 | { | 193 | { |
194 | struct backing_dev_info *bdi = &td->queue->backing_dev_info; | 194 | struct backing_dev_info *bdi = &td->queue->backing_dev_info; |
195 | unsigned int major, minor; | 195 | unsigned int major, minor; |
196 | 196 | ||
197 | if (!tg || tg->blkg.dev) | ||
198 | return; | ||
199 | |||
200 | /* | ||
201 | * Fill in device details for a group which might not have been | ||
202 | * filled at group creation time as queue was being instantiated | ||
203 | * and driver had not attached a device yet | ||
204 | */ | ||
205 | if (bdi->dev && dev_name(bdi->dev)) { | ||
206 | sscanf(dev_name(bdi->dev), "%u:%u", &major, &minor); | ||
207 | tg->blkg.dev = MKDEV(major, minor); | ||
208 | } | ||
209 | } | ||
210 | |||
211 | static void throtl_init_add_tg_lists(struct throtl_data *td, | ||
212 | struct throtl_grp *tg, struct blkio_cgroup *blkcg) | ||
213 | { | ||
214 | __throtl_tg_fill_dev_details(td, tg); | ||
215 | |||
197 | /* Add group onto cgroup list */ | 216 | /* Add group onto cgroup list */ |
198 | sscanf(dev_name(bdi->dev), "%u:%u", &major, &minor); | ||
199 | blkiocg_add_blkio_group(blkcg, &tg->blkg, (void *)td, | 217 | blkiocg_add_blkio_group(blkcg, &tg->blkg, (void *)td, |
200 | MKDEV(major, minor), BLKIO_POLICY_THROTL); | 218 | tg->blkg.dev, BLKIO_POLICY_THROTL); |
201 | 219 | ||
202 | tg->bps[READ] = blkcg_get_read_bps(blkcg, tg->blkg.dev); | 220 | tg->bps[READ] = blkcg_get_read_bps(blkcg, tg->blkg.dev); |
203 | tg->bps[WRITE] = blkcg_get_write_bps(blkcg, tg->blkg.dev); | 221 | tg->bps[WRITE] = blkcg_get_write_bps(blkcg, tg->blkg.dev); |
@@ -225,8 +243,6 @@ throtl_grp *throtl_find_tg(struct throtl_data *td, struct blkio_cgroup *blkcg) | |||
225 | { | 243 | { |
226 | struct throtl_grp *tg = NULL; | 244 | struct throtl_grp *tg = NULL; |
227 | void *key = td; | 245 | void *key = td; |
228 | struct backing_dev_info *bdi = &td->queue->backing_dev_info; | ||
229 | unsigned int major, minor; | ||
230 | 246 | ||
231 | /* | 247 | /* |
232 | * This is the common case when there are no blkio cgroups. | 248 | * This is the common case when there are no blkio cgroups. |
@@ -237,12 +253,7 @@ throtl_grp *throtl_find_tg(struct throtl_data *td, struct blkio_cgroup *blkcg) | |||
237 | else | 253 | else |
238 | tg = tg_of_blkg(blkiocg_lookup_group(blkcg, key)); | 254 | tg = tg_of_blkg(blkiocg_lookup_group(blkcg, key)); |
239 | 255 | ||
240 | /* Fill in device details for root group */ | 256 | __throtl_tg_fill_dev_details(td, tg); |
241 | if (tg && !tg->blkg.dev && bdi->dev && dev_name(bdi->dev)) { | ||
242 | sscanf(dev_name(bdi->dev), "%u:%u", &major, &minor); | ||
243 | tg->blkg.dev = MKDEV(major, minor); | ||
244 | } | ||
245 | |||
246 | return tg; | 257 | return tg; |
247 | } | 258 | } |
248 | 259 | ||