* [PATCH] i2c: nomadik: Fixup system suspend @ 2014-04-10 13:59 Ulf Hansson [not found] ` <1397138376-28427-1-git-send-email-ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> 0 siblings, 1 reply; 7+ messages in thread From: Ulf Hansson @ 2014-04-10 13:59 UTC (permalink / raw) To: Wolfram Sang, linux-i2c-u79uwXL29TY76Z2rM5mHXA Cc: Linus Walleij, Kevin Hilman, Daniel Lezcano, Alessandro Rubini, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r, Ulf Hansson For !CONFIG_PM_RUNTIME, the device were never put back into active state while resuming. For CONFIG_PM_RUNTIME, we blindly trusted the device to be inactive while we were about to handle it at suspend late, which is just too optimistic. Even if the driver uses pm_runtime_put_sync() after each tranfer to return it's runtime PM resources, there are no guarantees this will actually mean the device will inactivated. The reason is that the PM core will prevent runtime suspend during system suspend, and thus when a transfer occurs during the early phases of system suspend the device will be kept active after the transfer. To handle both issues above, use pm_runtime_force_suspend|resume() from the system suspend|resume callbacks. Cc: Alessandro Rubini <rubini-9wsNiZum9E8@public.gmane.org> Cc: Linus Walleij <linus.walleij-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> Cc: Wolfram Sang <wsa-z923LK4zBo2bacvFa/9K2g@public.gmane.org> Signed-off-by: Ulf Hansson <ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> --- Do note, this patch were sent during the previous kernel release cycle, as a part of another patchset on the PM core. Back then, it provided proof of concept, for the new runtime PM helper functions: pm_runtime_force_suspend|resume(). --- drivers/i2c/busses/i2c-nomadik.c | 14 +++++++------- 1 file changed, 7 insertions(+), 7 deletions(-) diff --git a/drivers/i2c/busses/i2c-nomadik.c b/drivers/i2c/busses/i2c-nomadik.c index 28cbe1b..7d27eee 100644 --- a/drivers/i2c/busses/i2c-nomadik.c +++ b/drivers/i2c/busses/i2c-nomadik.c @@ -879,19 +879,19 @@ static irqreturn_t i2c_irq_handler(int irq, void *arg) #ifdef CONFIG_PM_SLEEP static int nmk_i2c_suspend_late(struct device *dev) { - pinctrl_pm_select_sleep_state(dev); + int ret; + ret = pm_runtime_force_suspend(dev); + if (ret) + return ret; + + pinctrl_pm_select_sleep_state(dev); return 0; } static int nmk_i2c_resume_early(struct device *dev) { - /* First go to the default state */ - pinctrl_pm_select_default_state(dev); - /* Then let's idle the pins until the next transfer happens */ - pinctrl_pm_select_idle_state(dev); - - return 0; + return pm_runtime_force_resume(dev); } #endif -- 1.7.9.5 ^ permalink raw reply related [flat|nested] 7+ messages in thread
[parent not found: <1397138376-28427-1-git-send-email-ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org>]
* Re: [PATCH] i2c: nomadik: Fixup system suspend [not found] ` <1397138376-28427-1-git-send-email-ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> @ 2014-04-10 18:49 ` Linus Walleij [not found] ` <CACRpkdb8VJ_Qqype4uP_YJ5=RncJndFUZv_yDxmZwq5S=_yZ2g-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 2014-05-21 8:33 ` Wolfram Sang 1 sibling, 1 reply; 7+ messages in thread From: Linus Walleij @ 2014-04-10 18:49 UTC (permalink / raw) To: Ulf Hansson Cc: Wolfram Sang, linux-i2c-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Kevin Hilman, Daniel Lezcano, Alessandro Rubini, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org On Thu, Apr 10, 2014 at 3:59 PM, Ulf Hansson <ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> wrote: > For !CONFIG_PM_RUNTIME, the device were never put back into active > state while resuming. > > For CONFIG_PM_RUNTIME, we blindly trusted the device to be inactive > while we were about to handle it at suspend late, which is just too > optimistic. > > Even if the driver uses pm_runtime_put_sync() after each tranfer to > return it's runtime PM resources, there are no guarantees this will > actually mean the device will inactivated. The reason is that the PM > core will prevent runtime suspend during system suspend, and thus when > a transfer occurs during the early phases of system suspend the device > will be kept active after the transfer. > > To handle both issues above, use pm_runtime_force_suspend|resume() from > the system suspend|resume callbacks. > > Cc: Alessandro Rubini <rubini-9wsNiZum9E8@public.gmane.org> > Cc: Linus Walleij <linus.walleij-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> > Cc: Wolfram Sang <wsa-z923LK4zBo2bacvFa/9K2g@public.gmane.org> > Signed-off-by: Ulf Hansson <ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> Acked-by: Linus Walleij <linus.walleij-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> Yours, Linus Walleij ^ permalink raw reply [flat|nested] 7+ messages in thread
[parent not found: <CACRpkdb8VJ_Qqype4uP_YJ5=RncJndFUZv_yDxmZwq5S=_yZ2g-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>]
* Re: [PATCH] i2c: nomadik: Fixup system suspend [not found] ` <CACRpkdb8VJ_Qqype4uP_YJ5=RncJndFUZv_yDxmZwq5S=_yZ2g-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> @ 2014-05-06 9:31 ` Ulf Hansson [not found] ` <CAPDyKFo6K-mbtKcs8wPmc=E-t=Djs-ufi_+SLLpCKej+bEwbDw-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 0 siblings, 1 reply; 7+ messages in thread From: Ulf Hansson @ 2014-05-06 9:31 UTC (permalink / raw) To: Wolfram Sang Cc: Linus Walleij, linux-i2c-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Kevin Hilman, Daniel Lezcano, Alessandro Rubini, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org On 10 April 2014 20:49, Linus Walleij <linus.walleij-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> wrote: > On Thu, Apr 10, 2014 at 3:59 PM, Ulf Hansson <ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> wrote: > >> For !CONFIG_PM_RUNTIME, the device were never put back into active >> state while resuming. >> >> For CONFIG_PM_RUNTIME, we blindly trusted the device to be inactive >> while we were about to handle it at suspend late, which is just too >> optimistic. >> >> Even if the driver uses pm_runtime_put_sync() after each tranfer to >> return it's runtime PM resources, there are no guarantees this will >> actually mean the device will inactivated. The reason is that the PM >> core will prevent runtime suspend during system suspend, and thus when >> a transfer occurs during the early phases of system suspend the device >> will be kept active after the transfer. >> >> To handle both issues above, use pm_runtime_force_suspend|resume() from >> the system suspend|resume callbacks. >> >> Cc: Alessandro Rubini <rubini-9wsNiZum9E8@public.gmane.org> >> Cc: Linus Walleij <linus.walleij-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> >> Cc: Wolfram Sang <wsa-z923LK4zBo2bacvFa/9K2g@public.gmane.org> >> Signed-off-by: Ulf Hansson <ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> > > Acked-by: Linus Walleij <linus.walleij-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> Hi Wolfram, This patch as has been around for a while (in some other versions as well), would you mind picking it up for 3.16? Kind regards Ulf Hansson > > Yours, > Linus Walleij ^ permalink raw reply [flat|nested] 7+ messages in thread
[parent not found: <CAPDyKFo6K-mbtKcs8wPmc=E-t=Djs-ufi_+SLLpCKej+bEwbDw-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>]
* Re: [PATCH] i2c: nomadik: Fixup system suspend [not found] ` <CAPDyKFo6K-mbtKcs8wPmc=E-t=Djs-ufi_+SLLpCKej+bEwbDw-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> @ 2014-05-15 7:15 ` Ulf Hansson [not found] ` <CAPDyKFqxa3ZveRUWseT25cSOcn-6vUVBR0q515qsha1z0WfdNQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 0 siblings, 1 reply; 7+ messages in thread From: Ulf Hansson @ 2014-05-15 7:15 UTC (permalink / raw) To: Wolfram Sang Cc: Linus Walleij, linux-i2c-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Kevin Hilman, Daniel Lezcano, Alessandro Rubini, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org On 6 May 2014 11:31, Ulf Hansson <ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> wrote: > On 10 April 2014 20:49, Linus Walleij <linus.walleij-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> wrote: >> On Thu, Apr 10, 2014 at 3:59 PM, Ulf Hansson <ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> wrote: >> >>> For !CONFIG_PM_RUNTIME, the device were never put back into active >>> state while resuming. >>> >>> For CONFIG_PM_RUNTIME, we blindly trusted the device to be inactive >>> while we were about to handle it at suspend late, which is just too >>> optimistic. >>> >>> Even if the driver uses pm_runtime_put_sync() after each tranfer to >>> return it's runtime PM resources, there are no guarantees this will >>> actually mean the device will inactivated. The reason is that the PM >>> core will prevent runtime suspend during system suspend, and thus when >>> a transfer occurs during the early phases of system suspend the device >>> will be kept active after the transfer. >>> >>> To handle both issues above, use pm_runtime_force_suspend|resume() from >>> the system suspend|resume callbacks. >>> >>> Cc: Alessandro Rubini <rubini-9wsNiZum9E8@public.gmane.org> >>> Cc: Linus Walleij <linus.walleij-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> >>> Cc: Wolfram Sang <wsa-z923LK4zBo2bacvFa/9K2g@public.gmane.org> >>> Signed-off-by: Ulf Hansson <ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> >> >> Acked-by: Linus Walleij <linus.walleij-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> > > Hi Wolfram, > > This patch as has been around for a while (in some other versions as > well), would you mind picking it up for 3.16? > Ping. I noticed you merged my other i2c-nomadik patch yesterday - thought I might remind you about this one as well. Kind regards Ulf Hansson ^ permalink raw reply [flat|nested] 7+ messages in thread
[parent not found: <CAPDyKFqxa3ZveRUWseT25cSOcn-6vUVBR0q515qsha1z0WfdNQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>]
* Re: [PATCH] i2c: nomadik: Fixup system suspend [not found] ` <CAPDyKFqxa3ZveRUWseT25cSOcn-6vUVBR0q515qsha1z0WfdNQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> @ 2014-05-15 7:48 ` Wolfram Sang 2014-05-15 15:36 ` Ulf Hansson 0 siblings, 1 reply; 7+ messages in thread From: Wolfram Sang @ 2014-05-15 7:48 UTC (permalink / raw) To: Ulf Hansson Cc: Linus Walleij, linux-i2c-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Kevin Hilman, Daniel Lezcano, Alessandro Rubini, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org [-- Attachment #1: Type: text/plain, Size: 266 bytes --] > I noticed you merged my other i2c-nomadik patch yesterday - thought I > might remind you about this one as well. I was working on for-current. I'll start working on for-next these days. I use patchwork, as long as you cc the list, patches won't be forgotten ;) [-- Attachment #2: Digital signature --] [-- Type: application/pgp-signature, Size: 836 bytes --] ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] i2c: nomadik: Fixup system suspend 2014-05-15 7:48 ` Wolfram Sang @ 2014-05-15 15:36 ` Ulf Hansson 0 siblings, 0 replies; 7+ messages in thread From: Ulf Hansson @ 2014-05-15 15:36 UTC (permalink / raw) To: Wolfram Sang Cc: Linus Walleij, linux-i2c-u79uwXL29TY76Z2rM5mHXA@public.gmane.org, Kevin Hilman, Daniel Lezcano, Alessandro Rubini, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r@public.gmane.org On 15 May 2014 09:48, Wolfram Sang <wsa-z923LK4zBo2bacvFa/9K2g@public.gmane.org> wrote: > >> I noticed you merged my other i2c-nomadik patch yesterday - thought I >> might remind you about this one as well. > > I was working on for-current. I'll start working on for-next these days. > I use patchwork, as long as you cc the list, patches won't be forgotten > ;) Thanks Wolfram, sorry for nagging! :-) Kind regards Ulf Hansson > ^ permalink raw reply [flat|nested] 7+ messages in thread
* Re: [PATCH] i2c: nomadik: Fixup system suspend [not found] ` <1397138376-28427-1-git-send-email-ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> 2014-04-10 18:49 ` Linus Walleij @ 2014-05-21 8:33 ` Wolfram Sang 1 sibling, 0 replies; 7+ messages in thread From: Wolfram Sang @ 2014-05-21 8:33 UTC (permalink / raw) To: Ulf Hansson Cc: linux-i2c-u79uwXL29TY76Z2rM5mHXA, Linus Walleij, Kevin Hilman, Daniel Lezcano, Alessandro Rubini, linux-arm-kernel-IAPFreCvJWM7uuMidbF8XUB+6BGkLq7r [-- Attachment #1: Type: text/plain, Size: 1174 bytes --] On Thu, Apr 10, 2014 at 03:59:36PM +0200, Ulf Hansson wrote: > For !CONFIG_PM_RUNTIME, the device were never put back into active > state while resuming. > > For CONFIG_PM_RUNTIME, we blindly trusted the device to be inactive > while we were about to handle it at suspend late, which is just too > optimistic. > > Even if the driver uses pm_runtime_put_sync() after each tranfer to > return it's runtime PM resources, there are no guarantees this will > actually mean the device will inactivated. The reason is that the PM > core will prevent runtime suspend during system suspend, and thus when > a transfer occurs during the early phases of system suspend the device > will be kept active after the transfer. > > To handle both issues above, use pm_runtime_force_suspend|resume() from > the system suspend|resume callbacks. > > Cc: Alessandro Rubini <rubini-9wsNiZum9E8@public.gmane.org> > Cc: Linus Walleij <linus.walleij-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> > Cc: Wolfram Sang <wsa-z923LK4zBo2bacvFa/9K2g@public.gmane.org> > Signed-off-by: Ulf Hansson <ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> Applied to for-next, thanks! [-- Attachment #2: Digital signature --] [-- Type: application/pgp-signature, Size: 836 bytes --] ^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2014-05-21 8:33 UTC | newest] Thread overview: 7+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2014-04-10 13:59 [PATCH] i2c: nomadik: Fixup system suspend Ulf Hansson [not found] ` <1397138376-28427-1-git-send-email-ulf.hansson-QSEj5FYQhm4dnm+yROfE0A@public.gmane.org> 2014-04-10 18:49 ` Linus Walleij [not found] ` <CACRpkdb8VJ_Qqype4uP_YJ5=RncJndFUZv_yDxmZwq5S=_yZ2g-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 2014-05-06 9:31 ` Ulf Hansson [not found] ` <CAPDyKFo6K-mbtKcs8wPmc=E-t=Djs-ufi_+SLLpCKej+bEwbDw-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 2014-05-15 7:15 ` Ulf Hansson [not found] ` <CAPDyKFqxa3ZveRUWseT25cSOcn-6vUVBR0q515qsha1z0WfdNQ-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org> 2014-05-15 7:48 ` Wolfram Sang 2014-05-15 15:36 ` Ulf Hansson 2014-05-21 8:33 ` Wolfram Sang
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).