From: "Rafael J. Wysocki" <rjw@sisk.pl> To: Linux PM mailing list <linux-pm@lists.linux-foundation.org> Cc: Greg Kroah-Hartman <gregkh@suse.de>, Magnus Damm <magnus.damm@gmail.com>, Paul Walmsley <paul@pwsan.com>, Kevin Hilman <khilman@ti.com>, Alan Stern <stern@rowland.harvard.edu>, LKML <linux-kernel@vger.kernel.org>, linux-sh@vger.kernel.org Subject: [PATCH 5/8] PM: Introduce generic "noirq" callback routines for subsystems Date: Sat, 11 Jun 2011 20:36:50 +0000 [thread overview] Message-ID: <201106112236.50368.rjw@sisk.pl> (raw) In-Reply-To: <201106112223.04972.rjw@sisk.pl> From: Rafael J. Wysocki <rjw@sisk.pl> Introduce generic "noirq" power management callback routines for subsystems in addition to the "regular" generic PM callback routines. The new routines will be used, among other things, for implementing system-wide PM transitions support for generic PM domains. Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl> --- drivers/base/power/generic_ops.c | 90 ++++++++++++++++++++++++++++++++------- include/linux/pm.h | 6 ++ 2 files changed, 82 insertions(+), 14 deletions(-) Index: linux-2.6/drivers/base/power/generic_ops.c =================================--- linux-2.6.orig/drivers/base/power/generic_ops.c +++ linux-2.6/drivers/base/power/generic_ops.c @@ -94,12 +94,13 @@ int pm_generic_prepare(struct device *de * __pm_generic_call - Generic suspend/freeze/poweroff/thaw subsystem callback. * @dev: Device to handle. * @event: PM transition of the system under way. + * @bool: Whether or not this is the "noirq" stage. * * If the device has not been suspended at run time, execute the * suspend/freeze/poweroff/thaw callback provided by its driver, if defined, and * return its error code. Otherwise, return zero. */ -static int __pm_generic_call(struct device *dev, int event) +static int __pm_generic_call(struct device *dev, int event, bool noirq) { const struct dev_pm_ops *pm = dev->driver ? dev->driver->pm : NULL; int (*callback)(struct device *); @@ -109,16 +110,16 @@ static int __pm_generic_call(struct devi switch (event) { case PM_EVENT_SUSPEND: - callback = pm->suspend; + callback = noirq ? pm->suspend_noirq : pm->suspend; break; case PM_EVENT_FREEZE: - callback = pm->freeze; + callback = noirq ? pm->freeze_noirq : pm->freeze; break; case PM_EVENT_HIBERNATE: - callback = pm->poweroff; + callback = noirq ? pm->poweroff_noirq : pm->poweroff; break; case PM_EVENT_THAW: - callback = pm->thaw; + callback = noirq ? pm->thaw_noirq : pm->thaw; break; default: callback = NULL; @@ -129,42 +130,82 @@ static int __pm_generic_call(struct devi } /** + * pm_generic_suspend_noirq - Generic suspend_noirq callback for subsystems. + * @dev: Device to suspend. + */ +int pm_generic_suspend_noirq(struct device *dev) +{ + return __pm_generic_call(dev, PM_EVENT_SUSPEND, true); +} +EXPORT_SYMBOL_GPL(pm_generic_suspend_noirq); + +/** * pm_generic_suspend - Generic suspend callback for subsystems. * @dev: Device to suspend. */ int pm_generic_suspend(struct device *dev) { - return __pm_generic_call(dev, PM_EVENT_SUSPEND); + return __pm_generic_call(dev, PM_EVENT_SUSPEND, false); } EXPORT_SYMBOL_GPL(pm_generic_suspend); /** + * pm_generic_freeze_noirq - Generic freeze_noirq callback for subsystems. + * @dev: Device to freeze. + */ +int pm_generic_freeze_noirq(struct device *dev) +{ + return __pm_generic_call(dev, PM_EVENT_FREEZE, true); +} +EXPORT_SYMBOL_GPL(pm_generic_freeze_noirq); + +/** * pm_generic_freeze - Generic freeze callback for subsystems. * @dev: Device to freeze. */ int pm_generic_freeze(struct device *dev) { - return __pm_generic_call(dev, PM_EVENT_FREEZE); + return __pm_generic_call(dev, PM_EVENT_FREEZE, false); } EXPORT_SYMBOL_GPL(pm_generic_freeze); /** + * pm_generic_poweroff_noirq - Generic poweroff_noirq callback for subsystems. + * @dev: Device to handle. + */ +int pm_generic_poweroff_noirq(struct device *dev) +{ + return __pm_generic_call(dev, PM_EVENT_HIBERNATE, true); +} +EXPORT_SYMBOL_GPL(pm_generic_poweroff_noirq); + +/** * pm_generic_poweroff - Generic poweroff callback for subsystems. * @dev: Device to handle. */ int pm_generic_poweroff(struct device *dev) { - return __pm_generic_call(dev, PM_EVENT_HIBERNATE); + return __pm_generic_call(dev, PM_EVENT_HIBERNATE, false); } EXPORT_SYMBOL_GPL(pm_generic_poweroff); /** + * pm_generic_thaw_noirq - Generic thaw_noirq callback for subsystems. + * @dev: Device to thaw. + */ +int pm_generic_thaw_noirq(struct device *dev) +{ + return __pm_generic_call(dev, PM_EVENT_THAW, true); +} +EXPORT_SYMBOL_GPL(pm_generic_thaw_noirq); + +/** * pm_generic_thaw - Generic thaw callback for subsystems. * @dev: Device to thaw. */ int pm_generic_thaw(struct device *dev) { - return __pm_generic_call(dev, PM_EVENT_THAW); + return __pm_generic_call(dev, PM_EVENT_THAW, false); } EXPORT_SYMBOL_GPL(pm_generic_thaw); @@ -172,12 +213,13 @@ EXPORT_SYMBOL_GPL(pm_generic_thaw); * __pm_generic_resume - Generic resume/restore callback for subsystems. * @dev: Device to handle. * @event: PM transition of the system under way. + * @bool: Whether or not this is the "noirq" stage. * * Execute the resume/resotre callback provided by the @dev's driver, if * defined. If it returns 0, change the device's runtime PM status to 'active'. * Return the callback's error code. */ -static int __pm_generic_resume(struct device *dev, int event) +static int __pm_generic_resume(struct device *dev, int event, bool noirq) { const struct dev_pm_ops *pm = dev->driver ? dev->driver->pm : NULL; int (*callback)(struct device *); @@ -188,10 +230,10 @@ static int __pm_generic_resume(struct de switch (event) { case PM_EVENT_RESUME: - callback = pm->resume; + callback = noirq ? pm->resume_noirq : pm->resume; break; case PM_EVENT_RESTORE: - callback = pm->restore; + callback = noirq ? pm->restore_noirq : pm->restore; break; default: callback = NULL; @@ -212,22 +254,42 @@ static int __pm_generic_resume(struct de } /** + * pm_generic_resume_noirq - Generic resume_noirq callback for subsystems. + * @dev: Device to resume. + */ +int pm_generic_resume_noirq(struct device *dev) +{ + return __pm_generic_resume(dev, PM_EVENT_RESUME, true); +} +EXPORT_SYMBOL_GPL(pm_generic_resume_noirq); + +/** * pm_generic_resume - Generic resume callback for subsystems. * @dev: Device to resume. */ int pm_generic_resume(struct device *dev) { - return __pm_generic_resume(dev, PM_EVENT_RESUME); + return __pm_generic_resume(dev, PM_EVENT_RESUME, false); } EXPORT_SYMBOL_GPL(pm_generic_resume); /** + * pm_generic_restore_noirq - Generic restore_noirq callback for subsystems. + * @dev: Device to restore. + */ +int pm_generic_restore_noirq(struct device *dev) +{ + return __pm_generic_resume(dev, PM_EVENT_RESTORE, true); +} +EXPORT_SYMBOL_GPL(pm_generic_restore_noirq); + +/** * pm_generic_restore - Generic restore callback for subsystems. * @dev: Device to restore. */ int pm_generic_restore(struct device *dev) { - return __pm_generic_resume(dev, PM_EVENT_RESTORE); + return __pm_generic_resume(dev, PM_EVENT_RESTORE, false); } EXPORT_SYMBOL_GPL(pm_generic_restore); Index: linux-2.6/include/linux/pm.h =================================--- linux-2.6.orig/include/linux/pm.h +++ linux-2.6/include/linux/pm.h @@ -553,11 +553,17 @@ extern void __suspend_report_result(cons extern int device_pm_wait_for_dev(struct device *sub, struct device *dev); extern int pm_generic_prepare(struct device *dev); +extern int pm_generic_suspend_noirq(struct device *dev); extern int pm_generic_suspend(struct device *dev); +extern int pm_generic_resume_noirq(struct device *dev); extern int pm_generic_resume(struct device *dev); +extern int pm_generic_freeze_noirq(struct device *dev); extern int pm_generic_freeze(struct device *dev); +extern int pm_generic_thaw_noirq(struct device *dev); extern int pm_generic_thaw(struct device *dev); +extern int pm_generic_restore_noirq(struct device *dev); extern int pm_generic_restore(struct device *dev); +extern int pm_generic_poweroff_noirq(struct device *dev); extern int pm_generic_poweroff(struct device *dev); extern void pm_generic_complete(struct device *dev);
WARNING: multiple messages have this Message-ID (diff)
From: "Rafael J. Wysocki" <rjw@sisk.pl> To: Linux PM mailing list <linux-pm@lists.linux-foundation.org> Cc: "Greg Kroah-Hartman" <gregkh@suse.de>, Magnus Damm <magnus.damm@gmail.com>, Paul Walmsley <paul@pwsan.com>, Kevin Hilman <khilman@ti.com>, Alan Stern <stern@rowland.harvard.edu>, LKML <linux-kernel@vger.kernel.org>, linux-sh@vger.kernel.org Subject: [PATCH 5/8] PM: Introduce generic "noirq" callback routines for subsystems Date: Sat, 11 Jun 2011 22:36:50 +0200 [thread overview] Message-ID: <201106112236.50368.rjw@sisk.pl> (raw) In-Reply-To: <201106112223.04972.rjw@sisk.pl> From: Rafael J. Wysocki <rjw@sisk.pl> Introduce generic "noirq" power management callback routines for subsystems in addition to the "regular" generic PM callback routines. The new routines will be used, among other things, for implementing system-wide PM transitions support for generic PM domains. Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl> --- drivers/base/power/generic_ops.c | 90 ++++++++++++++++++++++++++++++++------- include/linux/pm.h | 6 ++ 2 files changed, 82 insertions(+), 14 deletions(-) Index: linux-2.6/drivers/base/power/generic_ops.c =================================================================== --- linux-2.6.orig/drivers/base/power/generic_ops.c +++ linux-2.6/drivers/base/power/generic_ops.c @@ -94,12 +94,13 @@ int pm_generic_prepare(struct device *de * __pm_generic_call - Generic suspend/freeze/poweroff/thaw subsystem callback. * @dev: Device to handle. * @event: PM transition of the system under way. + * @bool: Whether or not this is the "noirq" stage. * * If the device has not been suspended at run time, execute the * suspend/freeze/poweroff/thaw callback provided by its driver, if defined, and * return its error code. Otherwise, return zero. */ -static int __pm_generic_call(struct device *dev, int event) +static int __pm_generic_call(struct device *dev, int event, bool noirq) { const struct dev_pm_ops *pm = dev->driver ? dev->driver->pm : NULL; int (*callback)(struct device *); @@ -109,16 +110,16 @@ static int __pm_generic_call(struct devi switch (event) { case PM_EVENT_SUSPEND: - callback = pm->suspend; + callback = noirq ? pm->suspend_noirq : pm->suspend; break; case PM_EVENT_FREEZE: - callback = pm->freeze; + callback = noirq ? pm->freeze_noirq : pm->freeze; break; case PM_EVENT_HIBERNATE: - callback = pm->poweroff; + callback = noirq ? pm->poweroff_noirq : pm->poweroff; break; case PM_EVENT_THAW: - callback = pm->thaw; + callback = noirq ? pm->thaw_noirq : pm->thaw; break; default: callback = NULL; @@ -129,42 +130,82 @@ static int __pm_generic_call(struct devi } /** + * pm_generic_suspend_noirq - Generic suspend_noirq callback for subsystems. + * @dev: Device to suspend. + */ +int pm_generic_suspend_noirq(struct device *dev) +{ + return __pm_generic_call(dev, PM_EVENT_SUSPEND, true); +} +EXPORT_SYMBOL_GPL(pm_generic_suspend_noirq); + +/** * pm_generic_suspend - Generic suspend callback for subsystems. * @dev: Device to suspend. */ int pm_generic_suspend(struct device *dev) { - return __pm_generic_call(dev, PM_EVENT_SUSPEND); + return __pm_generic_call(dev, PM_EVENT_SUSPEND, false); } EXPORT_SYMBOL_GPL(pm_generic_suspend); /** + * pm_generic_freeze_noirq - Generic freeze_noirq callback for subsystems. + * @dev: Device to freeze. + */ +int pm_generic_freeze_noirq(struct device *dev) +{ + return __pm_generic_call(dev, PM_EVENT_FREEZE, true); +} +EXPORT_SYMBOL_GPL(pm_generic_freeze_noirq); + +/** * pm_generic_freeze - Generic freeze callback for subsystems. * @dev: Device to freeze. */ int pm_generic_freeze(struct device *dev) { - return __pm_generic_call(dev, PM_EVENT_FREEZE); + return __pm_generic_call(dev, PM_EVENT_FREEZE, false); } EXPORT_SYMBOL_GPL(pm_generic_freeze); /** + * pm_generic_poweroff_noirq - Generic poweroff_noirq callback for subsystems. + * @dev: Device to handle. + */ +int pm_generic_poweroff_noirq(struct device *dev) +{ + return __pm_generic_call(dev, PM_EVENT_HIBERNATE, true); +} +EXPORT_SYMBOL_GPL(pm_generic_poweroff_noirq); + +/** * pm_generic_poweroff - Generic poweroff callback for subsystems. * @dev: Device to handle. */ int pm_generic_poweroff(struct device *dev) { - return __pm_generic_call(dev, PM_EVENT_HIBERNATE); + return __pm_generic_call(dev, PM_EVENT_HIBERNATE, false); } EXPORT_SYMBOL_GPL(pm_generic_poweroff); /** + * pm_generic_thaw_noirq - Generic thaw_noirq callback for subsystems. + * @dev: Device to thaw. + */ +int pm_generic_thaw_noirq(struct device *dev) +{ + return __pm_generic_call(dev, PM_EVENT_THAW, true); +} +EXPORT_SYMBOL_GPL(pm_generic_thaw_noirq); + +/** * pm_generic_thaw - Generic thaw callback for subsystems. * @dev: Device to thaw. */ int pm_generic_thaw(struct device *dev) { - return __pm_generic_call(dev, PM_EVENT_THAW); + return __pm_generic_call(dev, PM_EVENT_THAW, false); } EXPORT_SYMBOL_GPL(pm_generic_thaw); @@ -172,12 +213,13 @@ EXPORT_SYMBOL_GPL(pm_generic_thaw); * __pm_generic_resume - Generic resume/restore callback for subsystems. * @dev: Device to handle. * @event: PM transition of the system under way. + * @bool: Whether or not this is the "noirq" stage. * * Execute the resume/resotre callback provided by the @dev's driver, if * defined. If it returns 0, change the device's runtime PM status to 'active'. * Return the callback's error code. */ -static int __pm_generic_resume(struct device *dev, int event) +static int __pm_generic_resume(struct device *dev, int event, bool noirq) { const struct dev_pm_ops *pm = dev->driver ? dev->driver->pm : NULL; int (*callback)(struct device *); @@ -188,10 +230,10 @@ static int __pm_generic_resume(struct de switch (event) { case PM_EVENT_RESUME: - callback = pm->resume; + callback = noirq ? pm->resume_noirq : pm->resume; break; case PM_EVENT_RESTORE: - callback = pm->restore; + callback = noirq ? pm->restore_noirq : pm->restore; break; default: callback = NULL; @@ -212,22 +254,42 @@ static int __pm_generic_resume(struct de } /** + * pm_generic_resume_noirq - Generic resume_noirq callback for subsystems. + * @dev: Device to resume. + */ +int pm_generic_resume_noirq(struct device *dev) +{ + return __pm_generic_resume(dev, PM_EVENT_RESUME, true); +} +EXPORT_SYMBOL_GPL(pm_generic_resume_noirq); + +/** * pm_generic_resume - Generic resume callback for subsystems. * @dev: Device to resume. */ int pm_generic_resume(struct device *dev) { - return __pm_generic_resume(dev, PM_EVENT_RESUME); + return __pm_generic_resume(dev, PM_EVENT_RESUME, false); } EXPORT_SYMBOL_GPL(pm_generic_resume); /** + * pm_generic_restore_noirq - Generic restore_noirq callback for subsystems. + * @dev: Device to restore. + */ +int pm_generic_restore_noirq(struct device *dev) +{ + return __pm_generic_resume(dev, PM_EVENT_RESTORE, true); +} +EXPORT_SYMBOL_GPL(pm_generic_restore_noirq); + +/** * pm_generic_restore - Generic restore callback for subsystems. * @dev: Device to restore. */ int pm_generic_restore(struct device *dev) { - return __pm_generic_resume(dev, PM_EVENT_RESTORE); + return __pm_generic_resume(dev, PM_EVENT_RESTORE, false); } EXPORT_SYMBOL_GPL(pm_generic_restore); Index: linux-2.6/include/linux/pm.h =================================================================== --- linux-2.6.orig/include/linux/pm.h +++ linux-2.6/include/linux/pm.h @@ -553,11 +553,17 @@ extern void __suspend_report_result(cons extern int device_pm_wait_for_dev(struct device *sub, struct device *dev); extern int pm_generic_prepare(struct device *dev); +extern int pm_generic_suspend_noirq(struct device *dev); extern int pm_generic_suspend(struct device *dev); +extern int pm_generic_resume_noirq(struct device *dev); extern int pm_generic_resume(struct device *dev); +extern int pm_generic_freeze_noirq(struct device *dev); extern int pm_generic_freeze(struct device *dev); +extern int pm_generic_thaw_noirq(struct device *dev); extern int pm_generic_thaw(struct device *dev); +extern int pm_generic_restore_noirq(struct device *dev); extern int pm_generic_restore(struct device *dev); +extern int pm_generic_poweroff_noirq(struct device *dev); extern int pm_generic_poweroff(struct device *dev); extern void pm_generic_complete(struct device *dev);
next prev parent reply other threads:[~2011-06-11 20:36 UTC|newest] Thread overview: 261+ messages / expand[flat|nested] mbox.gz Atom feed top 2011-06-11 20:23 [PATCH 0/8] PM / Domains: Support for generic I/O PM domains (v5) Rafael J. Wysocki 2011-06-11 20:23 ` Rafael J. Wysocki 2011-06-11 20:23 ` Rafael J. Wysocki 2011-06-11 20:25 ` [PATCH 1/8] PM / Domains: Update documentation Rafael J. Wysocki 2011-06-11 20:25 ` Rafael J. Wysocki 2011-06-11 20:25 ` Rafael J. Wysocki 2011-06-11 20:26 ` [PATCH 2/8] PM / Domains: Rename struct dev_power_domain to struct dev_pm_domain Rafael J. Wysocki 2011-06-11 20:26 ` Rafael J. Wysocki 2011-06-20 23:37 ` Kevin Hilman 2011-06-20 23:37 ` Kevin Hilman 2011-06-20 23:37 ` Kevin Hilman 2011-06-11 20:26 ` Rafael J. Wysocki 2011-06-11 20:27 ` [PATCH 3/8] PM: subsys_data in struct dev_pm_info need not depend on RM_RUNTIME Rafael J. Wysocki 2011-06-11 20:27 ` Rafael J. Wysocki 2011-06-11 20:27 ` Rafael J. Wysocki 2011-06-11 20:31 ` [PATCH 4/8] PM / Domains: Support for generic I/O PM domains (v5) Rafael J. Wysocki 2011-06-11 20:31 ` Rafael J. Wysocki 2011-06-11 20:31 ` Rafael J. Wysocki 2011-06-19 22:02 ` [Update][PATCH 4/8] PM / Domains: Support for generic I/O PM domains (v6) Rafael J. Wysocki 2011-06-19 22:02 ` Rafael J. Wysocki 2011-06-19 22:02 ` Rafael J. Wysocki 2011-06-21 17:42 ` Kevin Hilman 2011-06-21 17:42 ` Kevin Hilman 2011-06-21 17:42 ` Kevin Hilman 2011-06-22 0:07 ` Rafael J. Wysocki 2011-06-22 0:07 ` Rafael J. Wysocki 2011-06-22 19:51 ` Kevin Hilman 2011-06-22 19:51 ` Kevin Hilman 2011-06-22 19:51 ` Kevin Hilman 2011-06-22 21:30 ` Rafael J. Wysocki 2011-06-22 21:30 ` Rafael J. Wysocki 2011-06-22 21:30 ` Rafael J. Wysocki 2011-06-22 0:07 ` Rafael J. Wysocki 2011-06-11 20:36 ` Rafael J. Wysocki [this message] 2011-06-11 20:36 ` [PATCH 5/8] PM: Introduce generic "noirq" callback routines for subsystems Rafael J. Wysocki 2011-06-11 20:36 ` Rafael J. Wysocki 2011-06-11 20:37 ` [PATCH 6/8] PM / Domains: Move code from under #ifdef CONFIG_PM_RUNTIME Rafael J. Wysocki 2011-06-11 20:37 ` Rafael J. Wysocki 2011-06-11 20:37 ` Rafael J. Wysocki 2011-06-11 20:39 ` [PATCH 7/8] PM / Domains: System-wide transitions support for generic PM domains Rafael J. Wysocki 2011-06-11 20:39 ` Rafael J. Wysocki 2011-06-11 23:28 ` [Update][PATCH 7/8] PM / Domains: System-wide transitions support for generic domains (v2) Rafael J. Wysocki 2011-06-11 23:28 ` Rafael J. Wysocki 2011-06-11 23:28 ` Rafael J. Wysocki 2011-06-19 22:06 ` [Update][PATCH 7/8] PM / Domains: System-wide transitions support for generic domains (v3) Rafael J. Wysocki 2011-06-19 22:06 ` Rafael J. Wysocki 2011-06-20 23:05 ` Rafael J. Wysocki 2011-06-20 23:05 ` Rafael J. Wysocki 2011-06-20 23:05 ` Rafael J. Wysocki 2011-06-22 21:50 ` Kevin Hilman 2011-06-22 21:50 ` Kevin Hilman 2011-06-22 21:50 ` Kevin Hilman 2011-06-22 22:16 ` Rafael J. Wysocki 2011-06-22 22:16 ` Rafael J. Wysocki 2011-06-22 22:16 ` Rafael J. Wysocki 2011-06-22 22:18 ` Kevin Hilman 2011-06-22 22:18 ` Kevin Hilman 2011-06-22 22:22 ` Rafael J. Wysocki 2011-06-22 22:22 ` Rafael J. Wysocki 2011-06-23 13:57 ` [PATCH] PM / Runtime: Update documentation of interactions with system sleep Rafael J. Wysocki 2011-06-23 13:57 ` Rafael J. Wysocki 2011-06-24 18:25 ` Kevin Hilman 2011-06-24 18:25 ` Kevin Hilman 2011-06-24 18:25 ` Kevin Hilman 2011-06-23 13:57 ` Rafael J. Wysocki 2011-06-22 22:22 ` [Update][PATCH 7/8] PM / Domains: System-wide transitions support for generic domains (v3) Rafael J. Wysocki 2011-06-22 22:18 ` Kevin Hilman 2011-06-23 14:19 ` Alan Stern 2011-06-23 14:19 ` [Update][PATCH 7/8] PM / Domains: System-wide transitions support Alan Stern 2011-06-23 14:19 ` [Update][PATCH 7/8] PM / Domains: System-wide transitions support for generic domains (v3) Alan Stern 2011-06-23 14:44 ` Rafael J. Wysocki 2011-06-23 14:44 ` Rafael J. Wysocki 2011-06-23 14:44 ` Rafael J. Wysocki 2011-06-23 15:11 ` Alan Stern 2011-06-23 15:11 ` [Update][PATCH 7/8] PM / Domains: System-wide transitions support Alan Stern 2011-06-23 15:11 ` [Update][PATCH 7/8] PM / Domains: System-wide transitions support for generic domains (v3) Alan Stern 2011-06-23 17:41 ` Rafael J. Wysocki 2011-06-23 17:41 ` Rafael J. Wysocki 2011-06-23 17:41 ` Rafael J. Wysocki 2011-06-23 18:22 ` Alan Stern 2011-06-23 18:22 ` [Update][PATCH 7/8] PM / Domains: System-wide transitions support Alan Stern 2011-06-23 18:22 ` [Update][PATCH 7/8] PM / Domains: System-wide transitions support for generic domains (v3) Alan Stern 2011-06-23 21:03 ` Rafael J. Wysocki 2011-06-23 21:03 ` Rafael J. Wysocki 2011-06-23 21:03 ` Rafael J. Wysocki 2011-06-19 22:06 ` Rafael J. Wysocki 2011-06-11 20:39 ` [PATCH 7/8] PM / Domains: System-wide transitions support for generic PM domains Rafael J. Wysocki 2011-06-11 20:40 ` [PATCH 8/8] ARM / shmobile: Support for I/O PM domains for SH7372 (v5) Rafael J. Wysocki 2011-06-11 20:40 ` Rafael J. Wysocki 2011-06-11 20:40 ` Rafael J. Wysocki 2011-06-14 13:12 ` Magnus Damm 2011-06-14 13:12 ` Magnus Damm 2011-06-14 21:16 ` Rafael J. Wysocki 2011-06-14 21:16 ` Rafael J. Wysocki 2011-06-14 21:16 ` Rafael J. Wysocki 2011-06-15 14:17 ` Magnus Damm 2011-06-15 14:17 ` Magnus Damm 2011-06-15 23:06 ` Rafael J. Wysocki 2011-06-15 23:06 ` Rafael J. Wysocki 2011-06-19 22:07 ` [Update][PATCH 8/8] ARM / shmobile: Support for I/O power domains for SH7372 (v6) Rafael J. Wysocki 2011-06-19 22:07 ` Rafael J. Wysocki 2011-06-20 2:01 ` Paul Mundt 2011-06-20 2:01 ` Paul Mundt 2011-06-20 22:30 ` Rafael J. Wysocki 2011-06-20 22:30 ` Rafael J. Wysocki 2011-06-21 11:57 ` Rafael J. Wysocki 2011-06-21 11:57 ` Rafael J. Wysocki 2011-06-21 12:47 ` Paul Mundt 2011-06-21 12:47 ` Paul Mundt 2011-06-21 12:47 ` Paul Mundt 2011-06-21 11:57 ` Rafael J. Wysocki 2011-06-20 22:30 ` Rafael J. Wysocki 2011-06-20 2:01 ` Paul Mundt 2011-06-19 22:07 ` Rafael J. Wysocki 2011-06-15 23:06 ` [PATCH 8/8] ARM / shmobile: Support for I/O PM domains for SH7372 (v5) Rafael J. Wysocki 2011-07-10 11:45 ` Laurent Pinchart 2011-07-10 11:45 ` Laurent Pinchart 2011-07-10 11:45 ` Laurent Pinchart 2011-06-15 14:17 ` Magnus Damm 2011-06-14 13:12 ` Magnus Damm 2011-06-11 20:57 ` [PATCH 0/8] PM / Domains: Support for generic I/O PM domains (v5) Greg KH 2011-06-11 20:57 ` Greg KH 2011-06-11 20:57 ` Greg KH 2011-06-21 0:02 ` Kevin Hilman 2011-06-21 0:02 ` Kevin Hilman 2011-06-21 0:02 ` Kevin Hilman 2011-06-21 11:06 ` Rafael J. Wysocki 2011-06-21 11:06 ` Rafael J. Wysocki 2011-06-21 11:06 ` Rafael J. Wysocki 2011-06-21 14:47 ` Kevin Hilman 2011-06-21 14:47 ` [PATCH 0/8] PM / Domains: Support for generic I/O PM domains Kevin Hilman 2011-06-21 14:47 ` [PATCH 0/8] PM / Domains: Support for generic I/O PM domains (v5) Kevin Hilman 2011-06-25 21:24 ` [PATCH 0/10 v6] PM / Domains: Support for generic I/O PM domains Rafael J. Wysocki 2011-06-25 21:24 ` Rafael J. Wysocki 2011-06-25 21:24 ` [PATCH 1/10 v6] PM / Domains: Rename struct dev_power_domain to struct dev_pm_domain Rafael J. Wysocki 2011-06-25 21:24 ` Rafael J. Wysocki 2011-06-25 21:24 ` Rafael J. Wysocki 2011-06-25 21:25 ` [PATCH 2/10 v6] PM: subsys_data in struct dev_pm_info need not depend on RM_RUNTIME Rafael J. Wysocki 2011-06-25 21:25 ` Rafael J. Wysocki 2011-06-25 21:25 ` Rafael J. Wysocki 2011-06-25 21:26 ` [PATCH 3/10 v6] PM / Domains: Support for generic I/O PM domains (v7) Rafael J. Wysocki 2011-06-25 21:26 ` Rafael J. Wysocki 2011-06-25 21:26 ` Rafael J. Wysocki 2011-06-30 6:14 ` Ming Lei 2011-06-30 6:14 ` Ming Lei 2011-06-30 18:58 ` Rafael J. Wysocki 2011-06-30 18:58 ` Rafael J. Wysocki 2011-06-30 18:58 ` Rafael J. Wysocki 2011-06-30 6:14 ` Ming Lei 2011-07-01 18:11 ` Kevin Hilman 2011-07-01 18:11 ` Kevin Hilman 2011-07-01 20:03 ` Rafael J. Wysocki 2011-07-01 20:03 ` Rafael J. Wysocki 2011-07-01 20:03 ` Rafael J. Wysocki 2011-07-01 18:11 ` Kevin Hilman 2011-06-25 21:27 ` [PATCH 4/10 v6] PM: Introduce generic "noirq" callback routines for subsystems (v2) Rafael J. Wysocki 2011-06-25 21:27 ` Rafael J. Wysocki 2011-06-25 21:27 ` Rafael J. Wysocki 2011-06-25 21:27 ` [PATCH 5/10 v6] PM / Domains: Move code from under #ifdef CONFIG_PM_RUNTIME (v2) Rafael J. Wysocki 2011-06-25 21:27 ` Rafael J. Wysocki 2011-06-25 21:27 ` Rafael J. Wysocki 2011-06-25 21:28 ` [PATCH 6/10 v6] PM / Domains: System-wide transitions support for generic domains (v4) Rafael J. Wysocki 2011-06-25 21:28 ` Rafael J. Wysocki 2011-06-28 23:44 ` [Update][PATCH 6/10] PM / Domains: System-wide transitions support for generic domains (v5) Rafael J. Wysocki 2011-06-28 23:44 ` Rafael J. Wysocki 2011-06-28 23:44 ` Rafael J. Wysocki 2011-07-08 0:29 ` Kevin Hilman 2011-07-08 0:29 ` Kevin Hilman 2011-07-08 9:24 ` Rafael J. Wysocki 2011-07-08 9:24 ` Rafael J. Wysocki 2011-07-08 9:24 ` Rafael J. Wysocki 2011-07-08 14:37 ` [Update][PATCH 6/10] PM / Domains: System-wide transitions Alan Stern 2011-07-08 14:37 ` [Update][PATCH 6/10] PM / Domains: System-wide transitions support for generic domains (v5) Alan Stern 2011-07-08 17:20 ` Kevin Hilman 2011-07-08 17:20 ` Kevin Hilman 2011-07-08 17:20 ` Kevin Hilman 2011-07-08 18:06 ` Rafael J. Wysocki 2011-07-08 18:06 ` Rafael J. Wysocki 2011-07-08 19:24 ` Rafael J. Wysocki 2011-07-08 19:24 ` Rafael J. Wysocki 2011-07-08 19:24 ` Rafael J. Wysocki 2011-07-09 14:15 ` Rafael J. Wysocki 2011-07-09 14:15 ` Rafael J. Wysocki 2011-07-09 14:15 ` Rafael J. Wysocki 2011-07-11 15:37 ` Kevin Hilman 2011-07-11 15:37 ` Kevin Hilman 2011-07-11 15:37 ` Kevin Hilman 2011-07-11 19:39 ` Rafael J. Wysocki 2011-07-11 19:39 ` Rafael J. Wysocki 2011-07-11 19:39 ` Rafael J. Wysocki 2011-07-08 18:06 ` Rafael J. Wysocki 2011-07-08 17:56 ` Rafael J. Wysocki 2011-07-08 17:56 ` Rafael J. Wysocki 2011-07-08 17:56 ` Rafael J. Wysocki 2011-07-08 14:37 ` Alan Stern 2011-07-08 0:29 ` Kevin Hilman 2011-06-25 21:28 ` [PATCH 6/10 v6] PM / Domains: System-wide transitions support for generic domains (v4) Rafael J. Wysocki 2011-06-25 21:29 ` [PATCH 7/10 v6] PM / Domains: Don't stop wakeup devices during system sleep transitions Rafael J. Wysocki 2011-06-25 21:29 ` Rafael J. Wysocki 2011-06-25 21:29 ` Rafael J. Wysocki 2011-06-29 23:50 ` Kevin Hilman 2011-06-29 23:50 ` Kevin Hilman 2011-06-30 19:37 ` Rafael J. Wysocki 2011-06-30 19:37 ` Rafael J. Wysocki 2011-06-30 19:37 ` Rafael J. Wysocki 2011-06-30 22:42 ` Kevin Hilman 2011-06-30 22:42 ` Kevin Hilman 2011-06-30 22:42 ` Kevin Hilman 2011-06-30 22:55 ` Rafael J. Wysocki 2011-06-30 22:55 ` Rafael J. Wysocki 2011-06-30 22:55 ` Rafael J. Wysocki 2011-06-30 23:14 ` Kevin Hilman 2011-06-30 23:14 ` Kevin Hilman 2011-06-30 23:14 ` Kevin Hilman 2011-06-30 23:28 ` Rafael J. Wysocki 2011-06-30 23:28 ` Rafael J. Wysocki 2011-06-30 23:28 ` Rafael J. Wysocki 2011-07-01 0:01 ` Kevin Hilman 2011-07-01 0:01 ` Kevin Hilman 2011-07-01 0:01 ` Kevin Hilman 2011-07-01 0:24 ` Rafael J. Wysocki 2011-07-01 0:24 ` Rafael J. Wysocki 2011-07-01 0:24 ` Rafael J. Wysocki 2011-07-01 14:34 ` Kevin Hilman 2011-07-01 14:34 ` Kevin Hilman 2011-07-01 14:34 ` Kevin Hilman 2011-06-30 23:25 ` Rafael J. Wysocki 2011-06-30 23:25 ` Rafael J. Wysocki 2011-06-30 23:25 ` Rafael J. Wysocki 2011-07-01 14:45 ` [PATCH 7/10 v6] PM / Domains: Don't stop wakeup devices during Alan Stern 2011-07-01 14:45 ` [PATCH 7/10 v6] PM / Domains: Don't stop wakeup devices during system sleep transitions Alan Stern 2011-07-01 20:06 ` Rafael J. Wysocki 2011-07-01 20:06 ` Rafael J. Wysocki 2011-07-01 20:06 ` Rafael J. Wysocki 2011-07-01 14:45 ` Alan Stern 2011-06-29 23:50 ` Kevin Hilman 2011-06-25 21:30 ` [PATCH 8/10 v6] PM: Allow the clocks management code to be used during system suspend Rafael J. Wysocki 2011-06-25 21:30 ` Rafael J. Wysocki 2011-06-25 21:30 ` Rafael J. Wysocki 2011-06-25 21:30 ` [PATCH 9/10 v6] PM: Rename clock management functions Rafael J. Wysocki 2011-06-25 21:30 ` Rafael J. Wysocki 2011-06-25 21:30 ` Rafael J. Wysocki 2011-06-25 21:31 ` [PATCH 10/10 v6] ARM / shmobile: Support for I/O power domains for SH7372 (v8) Rafael J. Wysocki 2011-06-25 21:31 ` Rafael J. Wysocki 2011-06-27 4:07 ` [PATCH 10/10 v6] ARM / shmobile: Support for I/O power domains Magnus Damm 2011-06-27 4:07 ` [PATCH 10/10 v6] ARM / shmobile: Support for I/O power domains for SH7372 (v8) Magnus Damm 2011-06-27 4:07 ` Magnus Damm 2011-06-27 19:25 ` Rafael J. Wysocki 2011-06-27 19:25 ` Rafael J. Wysocki 2011-06-27 19:25 ` Rafael J. Wysocki 2011-06-27 23:21 ` [PATCH 10/10 v6] ARM / shmobile: Support for I/O power domains Magnus Damm 2011-06-27 23:21 ` [PATCH 10/10 v6] ARM / shmobile: Support for I/O power domains for SH7372 (v8) Magnus Damm 2011-06-27 23:21 ` Magnus Damm 2011-06-28 10:08 ` Rafael J. Wysocki 2011-06-28 10:08 ` Rafael J. Wysocki 2011-06-28 10:08 ` Rafael J. Wysocki 2011-06-25 21:31 ` Rafael J. Wysocki 2011-07-01 18:27 ` [PATCH 0/10 v6] PM / Domains: Support for generic I/O PM domains Kevin Hilman 2011-07-01 18:27 ` Kevin Hilman 2011-07-01 18:27 ` Kevin Hilman 2011-06-25 21:24 ` Rafael J. Wysocki
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=201106112236.50368.rjw@sisk.pl \ --to=rjw@sisk.pl \ --cc=gregkh@suse.de \ --cc=khilman@ti.com \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-pm@lists.linux-foundation.org \ --cc=linux-sh@vger.kernel.org \ --cc=magnus.damm@gmail.com \ --cc=paul@pwsan.com \ --cc=stern@rowland.harvard.edu \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.