diff options
author | Mike Snitzer <snitzer@redhat.com> | 2015-07-08 16:08:24 -0400 |
---|---|---|
committer | Mike Snitzer <snitzer@redhat.com> | 2015-07-08 16:16:07 -0400 |
commit | 621739b00e16ca2d80411dc9b111cb15b91f3ba9 (patch) | |
tree | 76870c96eaa41113cb8f99669531c9f53dba12a5 | |
parent | 1c7518794a3647eb345d59ee52844e8a40405198 (diff) | |
download | op-kernel-dev-621739b00e16ca2d80411dc9b111cb15b91f3ba9.zip op-kernel-dev-621739b00e16ca2d80411dc9b111cb15b91f3ba9.tar.gz |
Revert "dm: only run the queue on completion if congested or no requests pending"
This reverts commit 9a0e609e3fd8a95c96629b9fbde6b8c5b9a1456a.
(Resolved a conflict during revert due to commit bfebd1cdb4 that came
after)
This revert is motivated by a couple failure reports on request-based DM
multipath testbeds:
1) Netapp reported that their multipath fault injection test under heavy
IO load can stall longer than 300 seconds.
2) IBM reported elevated lock contention in their testbed (likely due to
increased back pressure due to IO not being dispatched as quickly):
https://www.redhat.com/archives/dm-devel/2015-July/msg00057.html
Signed-off-by: Mike Snitzer <snitzer@redhat.com>
Cc: stable@vger.kernel.org # 4.1+
-rw-r--r-- | drivers/md/dm.c | 8 |
1 files changed, 2 insertions, 6 deletions
diff --git a/drivers/md/dm.c b/drivers/md/dm.c index f331d88..de70377 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c @@ -1067,13 +1067,10 @@ static void rq_end_stats(struct mapped_device *md, struct request *orig) */ static void rq_completed(struct mapped_device *md, int rw, bool run_queue) { - int nr_requests_pending; - atomic_dec(&md->pending[rw]); /* nudge anyone waiting on suspend queue */ - nr_requests_pending = md_in_flight(md); - if (!nr_requests_pending) + if (!md_in_flight(md)) wake_up(&md->wait); /* @@ -1085,8 +1082,7 @@ static void rq_completed(struct mapped_device *md, int rw, bool run_queue) if (run_queue) { if (md->queue->mq_ops) blk_mq_run_hw_queues(md->queue, true); - else if (!nr_requests_pending || - (nr_requests_pending >= md->queue->nr_congestion_on)) + else blk_run_queue_async(md->queue); } |