Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755365AbZKWOmv (ORCPT ); Mon, 23 Nov 2009 09:42:51 -0500 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1755061AbZKWOmu (ORCPT ); Mon, 23 Nov 2009 09:42:50 -0500 Received: from cavan.codon.org.uk ([93.93.128.6]:56117 "EHLO cavan.codon.org.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753817AbZKWOmr (ORCPT ); Mon, 23 Nov 2009 09:42:47 -0500 Date: Mon, 23 Nov 2009 14:42:38 +0000 From: Matthew Garrett To: Jens Axboe Cc: Pavel Machek , Kay Sievers , David Zeuthen , linux-kernel@vger.kernel.org, linux-hotplug@vger.kernel.org Subject: Re: [PATCH] [RFC] Add support for uevents on block device idle changes Message-ID: <20091123144238.GA10275@srcf.ucam.org> References: <20091118194053.GB12944@srcf.ucam.org> <20091118195342.GA13627@srcf.ucam.org> <20091118200712.GA14026@srcf.ucam.org> <20091122233749.GA9699@ucw.cz> <20091123141754.GE8742@kernel.dk> <20091123142557.GA10084@srcf.ucam.org> <20091123143140.GG8742@kernel.dk> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20091123143140.GG8742@kernel.dk> User-Agent: Mutt/1.5.18 (2008-05-17) X-SA-Exim-Connect-IP: X-SA-Exim-Mail-From: mjg59@cavan.codon.org.uk X-SA-Exim-Scanned: No (on cavan.codon.org.uk); SAEximRunCond expanded to false Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1566 Lines: 33 On Mon, Nov 23, 2009 at 03:31:40PM +0100, Jens Axboe wrote: > Well, take a look at laptop mode. A timer per-io is probably > unavoidable, but doing it at IO completion could mean a big decrease in > timer activity as opposed to doing it for each incoming IO. And since > you are looking at when the disk is idle, it makes a lot more sense to > me to do that when the we complete a request (and have no further > pending IO) rather than on incoming IO. Right. The current implementation I have does a del_timer() at submission (which should be moved to post-merge) - that should be cheap in the common case of a new command being submitted when there's already commands outstanding. There's then a mod_timer() at completion time. That's still a certain amount of expense, but it should be less. > Your biggest performance issue here is going to be sync IO, since the > disk will go idle very briefly before being kicked into action again. Ok, I'll try to benchmark that. The alternative (polling) method would be something much like Kay suggested - either add an extra field to stat or an extra sysfs file, then invalidate that on submission and set to jiffies on completion. It's not ideal from a wakeups perspective, but it's pretty low impact on the kernel side. -- Matthew Garrett | mjg59@srcf.ucam.org -- 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/