Commit 52257ffb authored by Paolo Valente's avatar Paolo Valente Committed by Jens Axboe

block, bfq: put async queues for root bfq groups too

For each pair [device for which bfq is selected as I/O scheduler,
group in blkio/io], bfq maintains a corresponding bfq group. Each such
bfq group contains a set of async queues, with each async queue
created on demand, i.e., when some I/O request arrives for it.  On
creation, an async queue gets an extra reference, to make sure that
the queue is not freed as long as its bfq group exists.  Accordingly,
to allow the queue to be freed after the group exited, this extra
reference must released on group exit.

The above holds also for a bfq root group, i.e., for the bfq group
corresponding to the root blkio/io root for a given device. Yet, by
mistake, the references to the existing async queues of a root group
are not released when the latter exits. This causes a memory leak when
the instance of bfq for a given device exits. In a similar vein,
bfqg_stats_xfer_dead is not executed for a root group.

This commit fixes bfq_pd_offline so that the latter executes the above
missing operations for a root group too.
Reported-by: default avatarHolger Hoffstätte <holger@applied-asynchrony.com>
Reported-by: default avatarGuoqing Jiang <gqjiang@suse.com>
Tested-by: default avatarHolger Hoffstätte <holger@applied-asynchrony.com>
Signed-off-by: default avatarDavide Ferrari <davideferrari8@gmail.com>
Signed-off-by: default avatarPaolo Valente <paolo.valente@linaro.org>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 8ab0b7dc
...@@ -775,10 +775,11 @@ static void bfq_pd_offline(struct blkg_policy_data *pd) ...@@ -775,10 +775,11 @@ static void bfq_pd_offline(struct blkg_policy_data *pd)
unsigned long flags; unsigned long flags;
int i; int i;
spin_lock_irqsave(&bfqd->lock, flags);
if (!entity) /* root group */ if (!entity) /* root group */
return; goto put_async_queues;
spin_lock_irqsave(&bfqd->lock, flags);
/* /*
* Empty all service_trees belonging to this group before * Empty all service_trees belonging to this group before
* deactivating the group itself. * deactivating the group itself.
...@@ -809,6 +810,8 @@ static void bfq_pd_offline(struct blkg_policy_data *pd) ...@@ -809,6 +810,8 @@ static void bfq_pd_offline(struct blkg_policy_data *pd)
} }
__bfq_deactivate_entity(entity, false); __bfq_deactivate_entity(entity, false);
put_async_queues:
bfq_put_async_queues(bfqd, bfqg); bfq_put_async_queues(bfqd, bfqg);
spin_unlock_irqrestore(&bfqd->lock, flags); spin_unlock_irqrestore(&bfqd->lock, flags);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment