From: Mike Snitzer Date: Wed, 3 Feb 2016 03:35:06 +0000 (-0500) Subject: dm: cleanup dm_any_congested() X-Git-Url: http://drtracing.org/?a=commitdiff_plain;h=e522c039059b0fdf5ecd15d7007026326fffc9be;p=deliverable%2Flinux.git dm: cleanup dm_any_congested() The request-based DM support for checking queue congestion doesn't require access to the live DM table. Signed-off-by: Mike Snitzer --- diff --git a/drivers/md/dm.c b/drivers/md/dm.c index 30302df20201..d605170a02d9 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c @@ -2137,19 +2137,18 @@ static int dm_any_congested(void *congested_data, int bdi_bits) struct dm_table *map; if (!test_bit(DMF_BLOCK_IO_FOR_SUSPEND, &md->flags)) { - map = dm_get_live_table_fast(md); - if (map) { + if (dm_request_based(md)) { /* - * Request-based dm cares about only own queue for - * the query about congestion status of request_queue + * With request-based DM we only need to check the + * top-level queue for congestion. */ - if (dm_request_based(md)) - r = md->queue->backing_dev_info.wb.state & - bdi_bits; - else + r = md->queue->backing_dev_info.wb.state & bdi_bits; + } else { + map = dm_get_live_table_fast(md); + if (map) r = dm_table_any_congested(map, bdi_bits); + dm_put_live_table_fast(md); } - dm_put_live_table_fast(md); } return r;