Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753678Ab1FUOrT (ORCPT ); Tue, 21 Jun 2011 10:47:19 -0400 Received: from na3sys009aog105.obsmtp.com ([74.125.149.75]:47704 "EHLO na3sys009aog105.obsmtp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1750935Ab1FUOrQ (ORCPT ); Tue, 21 Jun 2011 10:47:16 -0400 Subject: Re: [PATCH 0/8] PM / Domains: Support for generic I/O PM domains (v5) From: Kevin Hilman To: "Rafael J. Wysocki" Cc: Greg Kroah-Hartman , Magnus Damm , Paul Walmsley , Alan Stern , LKML , Linux PM mailing list , linux-sh@vger.kernel.org In-Reply-To: <201106211306.26016.rjw@sisk.pl> References: <201106112223.04972.rjw@sisk.pl> <87boxs3vd3.fsf@ti.com> <201106211306.26016.rjw@sisk.pl> Content-Type: text/plain; charset="UTF-8" Organization: Texas Instruments, Inc. Date: Tue, 21 Jun 2011 07:47:12 -0700 Message-ID: <1308667632.2997.10.camel@vence> Mime-Version: 1.0 X-Mailer: Evolution 2.32.2 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 6158 Lines: 126 On Tue, 2011-06-21 at 13:06 +0200, Rafael J. Wysocki wrote: > On Tuesday, June 21, 2011, Kevin Hilman wrote: > > "Rafael J. Wysocki" writes: > > > > > Hi, > > > > > > This is the 4th update of the patchset adding support for generic I/O PM > > > domains. > > > > > > The patches have been reworked quite a bit to take feedback into > > > account, but I left the Greg's ACK in [4/8] in the hope it still applies > > > (Greg, please let me know in case it doesn't :-)). > > > > > > The model here is that a bunch of devices share a common power resource > > > that can be turned on and off by software. In addition to that, there > > > are means to start and stop the activity of each device, for example > > > by manipulating their clocks. Moreover, there may be hierarchy of > > > such things, for example power resource A may be necessary for devices > > > a, b, c, which don't rely on any other power resources, and for devices > > > x, y, z that also rely on power resource X. In that case there one PM > > > domain object representing devices a, b, c and power resource A, and > > > another PM domain object will represent devices x, y, z with power > > > resource X, plus the first object will be the second one's parent. > > > > > > Note to Kevin: I know you'd like each PM domain to be able to go into several > > > different states, but the situation will always be that in some of those > > > states the devices' registers will remain intact, while in the rest of those > > > states they will be reset. Say, there are states 1, 2, 3, 4 and states > > > 1-3 preserve device registers. Then it is not necessary to save device > > > registers for "domain" states 1-3 and it only is necessary to save them > > > when going to state 4. In that case, .power_off() may map to the "go to > > > state 4" operation (and analogously .power_on()), while the rest may be > > > done by .stop_device() and .start_device(). IOW, .power_is_off == true > > > means "the devices' registers have to be restored", so it need not map to > > > any particular physical state of a (hardware) power domain. > > > > Sure, but it's not only about register context save/restore. It's about > > the the governor hook and how you decide which state to enter. IOW, the > > governor decision is not only about whether or not you will lose > > register context but also about the latency involved in entering & > > exiting those states. > > > > So from my perspective, having only 2-states at this level makes the > > governor rather pointless since any decision making will have to be done > > where ever the knowledge of the mulitple power states lives. > > Well, in principle you can make the governor whatever you want, so it may > as well know of multiple states. > > Anyway, if using multiple domain states turns out to be useful at the core > level, it may be added later with a separate patch. OK > > > Note to Magnus and Paul: I didn't use a global lock as suggested, because > > > I think it may lead to completely unnecessary congestion in situations in > > > which there are no hierarchies of PM domains. It is quite easy to show that > > > the code doesn't deadlock, because (1) no more than 2 locks are held by the > > > same thread at a time (parent lock and child lock) and (2) they are always > > > acquired in the same order (parent before the child). > > > > > > Overall, I think I've taken all of the important dependencies into > > > consideration, but if you spot something suspicious, please let me know. :-) > > > Wakeup is not covered at this point, because it's not necessary for the > > > SH7372's A4LC power domain that's the first user of the new code, but it > > > is quite clear how add the support for it. Also, for more complicated > > > cases it is necessary to take QoS requirements (latencies) into account, > > > which is in the works (kind of). > > > > > > [1/8] - Update documentation to reflect the fact that struct dev_power_domain > > > callbacks take precedence over subsystem PM callbacks. > > > > > > [2/8] - Rename struct dev_power_domain to struct dev_pm_domain to reflect the > > > fact that those objects need not correspond to hardware power domains > > > directly. > > > > > > [3/8] - Move subsys_data in struct dev_pm_info out of #ifdef CONFIG_PM_RUNTIME > > > > > > [4/8] - Introduce runtime PM support for generic I/O PM domains. > > > > > > [5/8] - Introduce generic "noirq" callbacks for system suspend/hibernation > > > (that's necessary for the next patches). > > > > > > [6/8] - Move some PM domains support code fro under #ifdef CONFIG_PM_RUNTIME > > > > > > [7/8] - Add system-wide PM support for generic I/O PM domains. > > > > > > [8/8] - Use the new code to represent the SH7372's A4MP power domain. > > > > > > The patchset has been tested on SH7372 Mackerel board and appears to work > > > correctly. > > > > > > I'd like to push [1/8] for 3.0 (it may be regarded as a fix), but I _think_ > > > that it may be a good idea to push [2/8] for 3.0 too, to limit the time in > > > which people may possibly use the naming that's going to change in their new > > > code. If you agree with that, please let me know, I'll need some serious > > > ACKs below that patch if it's to be pushed for 3.0. ;-) > > > > Just gave you my ack, > > I thought the ACK was for [2/8] only, so do I understand correctly that it's > for the entire series? :-) So far, only for 2/8. I'm planning to spend some time looking at the rest of the series today. Kevin > > but [2/8] will need a minor update to apply on > > Linus' master branch since another fix to mach-omap1/pm_bus.c just got > > merged[1] via the OMAP tree. > > Yes, I already rebased my patches on top of 3.0-rc4. > > > I don't have any other fixes touching those files queued for v3.0 so I > > don't expect any other conflicts there. > > Thanks, > 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/