Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1030897Ab3DSOwa (ORCPT ); Fri, 19 Apr 2013 10:52:30 -0400 Received: from mail-pd0-f179.google.com ([209.85.192.179]:51340 "EHLO mail-pd0-f179.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1030730Ab3DSOw1 (ORCPT ); Fri, 19 Apr 2013 10:52:27 -0400 From: Kevin Hilman To: Sourav Poddar Cc: , , , , , Subject: Re: [PATCH 4/6] arm: mach-omap2: remove "OMAP_DEVICE_NO_IDLE_ON_SUSPEND" check References: <1366198467-6757-1-git-send-email-sourav.poddar@ti.com> <1366198467-6757-5-git-send-email-sourav.poddar@ti.com> <87li8f4sum.fsf@linaro.org> <5170434C.7040706@ti.com> <874nf31opn.fsf@linaro.org> <51714CCC.9090800@ti.com> Date: Fri, 19 Apr 2013 07:52:23 -0700 In-Reply-To: <51714CCC.9090800@ti.com> (Sourav Poddar's message of "Fri, 19 Apr 2013 19:25:24 +0530") Message-ID: <871ua6zi6w.fsf@linaro.org> User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/24.1 (gnu/linux) MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2365 Lines: 64 Sourav Poddar writes: [...] > Yes, got your point. omap_device_idle should not be called only > for console uart. > > Just did a quick testing by including the following hunk on top of my > patch series.. > > diff --git a/arch/arm/mach-omap2/omap_device.c > b/arch/arm/mach-omap2/omap_device.c > index c226946..7480e87 100644 > --- a/arch/arm/mach-omap2/omap_device.c > +++ b/arch/arm/mach-omap2/omap_device.c > @@ -617,8 +617,10 @@ static int _od_suspend_noirq(struct device *dev) > ret = pm_generic_suspend_noirq(dev); > > if (!ret && !pm_runtime_status_suspended(dev)) { > - if (pm_generic_runtime_suspend(dev) == 0) > + if (pm_generic_runtime_suspend(dev) == 0) { > + omap_device_idle(pdev); > od->flags |= OMAP_DEVICE_SUSPENDED; > + } > } > > return ret; > @@ -631,6 +633,7 @@ static int _od_resume_noirq(struct device *dev) > > if ((od->flags & OMAP_DEVICE_SUSPENDED) && > !pm_runtime_status_suspended(dev)) { > + omap_device_enable(pdev); > od->flags &= ~OMAP_DEVICE_SUSPENDED; > pm_generic_runtime_resume(dev); > } > And found the wakeup from UART is no more functional. > So, the omap_device_idle gets called for console UART also, thereby > preventing the "no_idle_on_suspend" theory. > > Hence, merely putting prepare/complete callback the way I did is not > helping. > We need to delete omap_device_idle also, which I agree is not correct. > So, we need a way to bypass this "omap_device_idle" > call for console UART. ? OK, I see what's happening now. How about this: rather than using prepare/complete callbacks, can you use the runtime_suspend callback to return an error code during suspend? (only for the console, and only when no_console_suspend is enabled, and only during suspend) Since _od_suspend_noirq checks to be sure the drivers ->runtime_suspend callback succeeds before it calls omap_device_idle(), if you report a failure, omap_device_idle will not be called. Kevin -- 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/