Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756596Ab0ANJEM (ORCPT ); Thu, 14 Jan 2010 04:04:12 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1756579Ab0ANJEL (ORCPT ); Thu, 14 Jan 2010 04:04:11 -0500 Received: from mga09.intel.com ([134.134.136.24]:24615 "EHLO mga09.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755974Ab0ANJEJ (ORCPT ); Thu, 14 Jan 2010 04:04:09 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="4.49,274,1262592000"; d="scan'208";a="587050255" Date: Thu, 14 Jan 2010 17:04:06 +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: <20100114090406.GA23847@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> <20100114061731.GA23590@sli10-desk.sh.intel.com> <4B4ED420.2020701@cn.fujitsu.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <4B4ED420.2020701@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: 2845 Lines: 49 On Thu, Jan 14, 2010 at 04:21:52PM +0800, Gui Jianfeng wrote: > Shaohua Li wrote: > > 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. > > I see your point, whether can we add the extra sync queue check into cfq_should_idle > for common use? yes. 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/