[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <1284972817.6598.19.camel@sli10-conroe.sh.intel.com>
Date: Mon, 20 Sep 2010 16:53:37 +0800
From: Shaohua Li <shaohua.li@...el.com>
To: lkml <linux-kernel@...r.kernel.org>
Cc: jaxboe@...ionio.com, vgoyal@...hat.com, czoccolo@...il.com
Subject: [patch]cfq-iosched: schedule dispatch for noidle queue
A queue is idle at cfq_dispatch_requests(), but it gets noidle later for
different reasons. Unless other task explictly does unplug or all requests
are drained, we will not deliever requests to the disk even cfq_arm_slice_timer
doesn't make the queue idle. For example, cfq_should_idle() returns true
because of service_tree->count == 1, and then other queues are added.
Note, I didn't see obvious performance impacts so far with the patch, but
just thought this could be a problem.
Signed-off-by: Shaohua Li <shaohua.li@...el.com>
---
block/cfq-iosched.c | 23 ++++++++++++++++++++++-
1 file changed, 22 insertions(+), 1 deletion(-)
Index: linux-2.6/block/cfq-iosched.c
===================================================================
--- linux-2.6.orig/block/cfq-iosched.c 2010-09-21 00:20:46.000000000 +0800
+++ linux-2.6/block/cfq-iosched.c 2010-09-21 00:22:58.000000000 +0800
@@ -3256,6 +3256,10 @@
if (cfq_class_rt(new_cfqq) && !cfq_class_rt(cfqq))
return true;
+ /* An idle queue should not be idle now for different reasons */
+ if (RB_EMPTY_ROOT(&cfqq->sort_list) && !cfq_should_idle(cfqd, cfqq))
+ return true;
+
if (!cfqd->active_cic || !cfq_cfqq_wait_request(cfqq))
return false;
@@ -3509,8 +3513,25 @@
}
}
- if (!cfqd->rq_in_driver)
+ if (!cfqd->rq_in_driver) {
+ cfq_schedule_dispatch(cfqd);
+ return;
+ }
+ /*
+ * A queue is idle at cfq_dispatch_requests(), but it gets noidle later
+ * for different reasons. We schedule a dispatch if the queue has no
+ * requests, otherwise the disk is actually in idle till all requests
+ * are finished even cfq_arm_slice_timer doesn't make the queue idle
+ * */
+ cfqq = cfqd->active_queue;
+ if (!cfqq)
+ return;
+
+ if (RB_EMPTY_ROOT(&cfqq->sort_list) && !cfq_should_idle(cfqd, cfqq) &&
+ (!cfqd->cfq_group_idle || cfqq->cfqg->nr_cfqq > 1)) {
+ cfq_del_timer(cfqd, cfqq);
cfq_schedule_dispatch(cfqd);
+ }
}
/*
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists