From mboxrd@z Thu Jan 1 00:00:00 1970 From: "Rafael J. Wysocki" Subject: Re: [patch update] Re: Run-time PM idea (was: Re: [RFC][PATCH 0/2] PM: Rearrange core suspend code) Date: Thu, 11 Jun 2009 00:01:20 +0200 Message-ID: <200906110001.20718.rjw__41319.4036031657$1244671305$gmane$org@sisk.pl> References: <200906102127.57136.rjw@sisk.pl> <200906102338.35183.oliver@neukum.org> Mime-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <200906102338.35183.oliver@neukum.org> Content-Disposition: inline List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: linux-pm-bounces@lists.linux-foundation.org Errors-To: linux-pm-bounces@lists.linux-foundation.org To: Oliver Neukum Cc: ACPI Devel Maling List , linux-pm@lists.linux-foundation.org, LKML List-Id: linux-pm@vger.kernel.org On Wednesday 10 June 2009, Oliver Neukum wrote: > Am Mittwoch, 10. Juni 2009 21:27:56 schrieb Rafael J. Wysocki: > > > What happens if the parent's parent is also suspended? It seems to me > > > that you must code this recursively. > > > > Hmm, I thought I did. > > > > [Looks] > > > > pm_request_resume(dev) will call pm_request_resume(dev->parent), if > > necessary, and that will call pm_request_resume(dev->parent->parent) and so > > on. Each of them will queue a work item and the one for the topmost parent > > will be queued first. So, the resume requests for all parents will be > > executed before the one for the device, due to the fact that the workqueue > > is singlethread. > > Sneaky, I overlooked that. > > > Well, there is a bug related to it, namely pm_autosuspend() may change the > > status to RPM_SUSPENDED after pm_request_resume() has changed it to > > RPM_WAKE, that needs fixing. > > Ok, maybe this is related. You recurse if the parent isn't in RPM_ACTIVE. > But that is not enough. You must ensure that all the nodes higher up stay > in RPM_ACTIVE. It seems to me that you must go up until you find an > active node (or the root) and put it a blocked state. If you're referring to pm_autoresume(), then this again is tricky. We have queued up resume requests for the device's parent, its parent etc., the topmost one goes first. The workqueue is singlethread, so pm_autoresume() is going to be run for all parents before the device itself, so if that were the only resume mechanism, it would be enough to check if the parent is RPM_ACTIVE. *However*, there also is pm_resume_sync(), which can take the device directly from RPM_SUSPENDED to RPM_RESUMING and that may be done in parallel with our pm_autoresume(). That's why I put the wait_for_completion() in there. Best, Rafael