Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754824Ab0ANDly (ORCPT ); Wed, 13 Jan 2010 22:41:54 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752642Ab0ANDly (ORCPT ); Wed, 13 Jan 2010 22:41:54 -0500 Received: from mga03.intel.com ([143.182.124.21]:60075 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751292Ab0ANDlx (ORCPT ); Wed, 13 Jan 2010 22:41:53 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="4.47,316,1257148800"; d="scan'208";a="232549447" Date: Thu, 14 Jan 2010 11:41:50 +0800 From: Shaohua Li To: Vivek Goyal Cc: Corrado Zoccolo , "jens.axboe@oracle.com" , "linux-kernel@vger.kernel.org" , "jmoyer@redhat.com" , "guijianfeng@cn.fujitsu.com" , "yanmin_zhang@linux.intel.com" Subject: Re: [PATCH]cfq-iosched: don't stop async queue with async requests pending Message-ID: <20100114034150.GA3922@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> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20100113111341.GB3087@redhat.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: 2125 Lines: 37 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. you are the expert of iogroup. If I'm wrong, I'll be happy to change cfq_should_idle(), which is the ideal place to be changed at my first glance. 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/