Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758496AbZFXART (ORCPT ); Tue, 23 Jun 2009 20:17:19 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752429AbZFXARI (ORCPT ); Tue, 23 Jun 2009 20:17:08 -0400 Received: from ogre.sisk.pl ([217.79.144.158]:40067 "EHLO ogre.sisk.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751915AbZFXARG (ORCPT ); Tue, 23 Jun 2009 20:17:06 -0400 From: "Rafael J. Wysocki" To: Alan Stern Subject: Re: [patch update 3] PM: Introduce core framework for run-time PM of I/O devices Date: Wed, 24 Jun 2009 02:17:38 +0200 User-Agent: KMail/1.11.2 (Linux/2.6.30-rjw; KDE/4.2.4; x86_64; ; ) Cc: Oliver Neukum , Magnus Damm , linux-pm@lists.linux-foundation.org, ACPI Devel Maling List , Ingo Molnar , LKML , Greg KH References: In-Reply-To: MIME-Version: 1.0 Content-Type: Text/Plain; charset="iso-8859-1" Content-Transfer-Encoding: 7bit Content-Disposition: inline Message-Id: <200906240217.39608.rjw@sisk.pl> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2347 Lines: 53 On Tuesday 23 June 2009, Alan Stern wrote: > On Tue, 23 Jun 2009, Rafael J. Wysocki wrote: > > > In short, I think suspending (or queuing a suspend request) should fail if the > > usage counter is nonzero, but the resuming (or queuing up a resume request) > > should be possible regardless of its value. The reason is that multiple > > threads may in theory attempt to resume the device at the same time. > > Agreed. Suspends and resumes aren't symmetrical -- a single resume > request must outweigh numerous suspend requests. > > > However, I'm not sure if the core should manipulate the usage counter by > > itself, because it's sort of problematic (there's no good approach to decide > > when to decrement the counter). > > Yes. The idea behind my previous message was that it's not really so > easy for the core to decide when to _increment_ the counter either. > > > So, I'd let the callers use pm_runtime_get() to increment the counter > > and pm_runtime_put() to decrement it, possibly queuing up an idle notification > > if the counter happens to reach 0. Also, I'm not sure if unbalanced > > pm_runtime_put() should be regarded as a bug. > > It should be. Once the counter is messed up, runtime PM wouldn't be > able to work properly. But maybe you should add a pm_set_counter call > so that drivers can recover from imbalances. > > One question still remains: If the counter is 0 at the end of a > successful pm_runtime_resume, should the core then call pm_notify_idle? > Or should we make the driver responsible for that too? Good question. :-) I think the core may call pm_notify_idle() in that case, but not necessarily in the synchronous case. > > At the same time, I'd like the core to use runtime_status and the other > > fields in dev_pm_info, except for the usage counter, to ensure that all > > operations are only carried out when it makes sense. > > Yes. In fact, I'd say that when the counter is positive it doesn't > make sense to allow a runtime suspend -- so you don't need that > exception in your statement above. :-) Well, you're right. Best, Rafael -- 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/