Commit 02a8f01b5a9f396d0327977af4c232d0f94c45fd

Authored by Justin TerAvest
Committed by Jens Axboe
1 parent be2c6b1990

cfq-iosched: Don't wait if queue already has requests.

Commit 7667aa0630407bc07dc38dcc79d29cc0a65553c1 added logic to wait for
the last queue of the group to become busy (have at least one request),
so that the group does not lose out for not being continuously
backlogged. The commit did not check for the condition that the last
queue already has some requests. As a result, if the queue already has
requests, wait_busy is set. Later on, cfq_select_queue() checks the
flag, and decides that since the queue has a request now and wait_busy
is set, the queue is expired.  This results in early expiration of the
queue.

This patch fixes the problem by adding a check to see if queue already
has requests. If it does, wait_busy is not set. As a result, time slices
do not expire early.

The queues with more than one request are usually buffered writers.
Testing shows improvement in isolation between buffered writers.

Cc: stable@kernel.org
Signed-off-by: Justin TerAvest <teravest@google.com>
Reviewed-by: Gui Jianfeng <guijianfeng@cn.fujitsu.com>
Acked-by: Vivek Goyal <vgoyal@redhat.com>
Signed-off-by: Jens Axboe <jaxboe@fusionio.com>

Showing 1 changed file with 4 additions and 0 deletions Side-by-side Diff

... ... @@ -3432,6 +3432,10 @@
3432 3432 {
3433 3433 struct cfq_io_context *cic = cfqd->active_cic;
3434 3434  
  3435 + /* If the queue already has requests, don't wait */
  3436 + if (!RB_EMPTY_ROOT(&cfqq->sort_list))
  3437 + return false;
  3438 +
3435 3439 /* If there are other queues in the group, don't wait */
3436 3440 if (cfqq->cfqg->nr_cfqq > 1)
3437 3441 return false;