Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755374Ab0ANGRf (ORCPT ); Thu, 14 Jan 2010 01:17:35 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1751431Ab0ANGRe (ORCPT ); Thu, 14 Jan 2010 01:17:34 -0500 Received: from mga09.intel.com ([134.134.136.24]:32940 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751056Ab0ANGRd (ORCPT ); Thu, 14 Jan 2010 01:17:33 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="4.49,273,1262592000"; d="scan'208";a="587017698" Date: Thu, 14 Jan 2010 14:17:31 +0800 From: Shaohua Li To: Gui Jianfeng Cc: Vivek Goyal , Corrado Zoccolo , "jens.axboe@oracle.com" , "linux-kernel@vger.kernel.org" , "jmoyer@redhat.com" , "yanmin_zhang@linux.intel.com" Subject: Re: [PATCH]cfq-iosched: don't stop async queue with async requests pending Message-ID: <20100114061731.GA23590@sli10-desk.sh.intel.com> References: <20100113074442.GA10492@sli10-desk.sh.intel.com> <4e5e476b1001130018n2ad9e830s4a20d922abd4c7bb@mail.gmail.com> <20100113082322.GA24345@sli10-desk.sh.intel.com> <20100113111341.GB3087@redhat.com> <20100114034150.GA3922@sli10-desk.sh.intel.com> <4B4EAB39.1070301@cn.fujitsu.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <4B4EAB39.1070301@cn.fujitsu.com> User-Agent: Mutt/1.5.20 (2009-06-14) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2571 Lines: 44 On Thu, Jan 14, 2010 at 01:27:21PM +0800, Gui Jianfeng wrote: > Shaohua Li wrote: > > On Wed, Jan 13, 2010 at 07:13:41PM +0800, Vivek Goyal wrote: > >> On Wed, Jan 13, 2010 at 04:23:22PM +0800, Shaohua Li wrote: > >>> On Wed, Jan 13, 2010 at 04:18:47PM +0800, Corrado Zoccolo wrote: > >>>> On Wed, Jan 13, 2010 at 8:44 AM, Shaohua Li wrote: > >>>>> My SSD speed of direct write is about 80m/s, while I test page writeback, > >>>>> the speed can only go to 68m/s. Below patch fixes this. > >>>>> It appears we missused cfq_should_idle in cfq_may_dispatch. cfq_should_idle > >>>>> means a queue should idle because it's seekless sync queue or it's the last queue, > >>>>> which is to maintain service tree time slice. So it doesn't mean the > >>>>> last queue is always a sync queue. If the last queue is asyn queue, > >>>>> we definitely shouldn't stop dispatch requests because of pending async > >>>>> requests. > >>>> An other option is that cfq_should_idle returns false for async > >>>> queues, since cfq will never idle on them. > >>> I'm considering this option too, but it appears we need make async queue > >>> idle to maintain domain time slice. > >> IMHO, we don't have to wait on async write service tree. Generally aysnc > >> write queus contain many requests and they are not like reads where next > >> request is expected. So idling on aysnc write service tree is waste of > >> time and will lead to reduced throughput. > > I fully agree async queue doesn't need wait. I thought the purpose we add the last > > queue check in cfq_should_idle is we want a service tree or a group has dedicated > > slice, because before the service tree/group slice is expired, new queue can jump > > in and if we don't idle, the new queue can only run at next slice. Not sure if I > > understand the code correctly. > > Hi Shaohua, > > If a cfq queue is the last one in the io group, if we expire this cfqq immediately, > io group will be removed from service tree. When io group gets backlogged again, it > will be put at the end of service tree, so it loses its previous share. so we add > the last check here from the fairness point of view. ya, this is what I'm understanding. So we can't return false for async queue in cfq_should_idle if the queue is the last one of service tree. Thanks, Shaohua -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/