From: Felipe Balbi <balbi@ti.com>
To: Felipe Balbi <balbi@ti.com>
Cc: "\\\"Venkatraman S.\\\"" <svenkatr@ti.com>,
Linux OMAP Mailing List <linux-omap@vger.kernel.org>,
linux-mmc@vger.kernel.org, cjb@laptop.org,
Tony Lindgren <tony@atomide.com>, Balaji T K <balajitk@ti.com>,
Linux ARM Kernel Mailing List
<linux-arm-kernel@lists.infradead.org>
Subject: Re: [RFC/PATCH] mmc: omap_hsmmc: introduce omap_hsmmc_prepare/complete
Date: Mon, 22 Oct 2012 16:27:08 +0300 [thread overview]
Message-ID: <20121022132708.GA14033@arwen.pp.htv.fi> (raw)
In-Reply-To: <1350910768-8522-1-git-send-email-balbi@ti.com>
[-- Attachment #1: Type: text/plain, Size: 3545 bytes --]
On Mon, Oct 22, 2012 at 03:59:28PM +0300, Felipe Balbi wrote:
> prepare() is supposed to prevent new children from
> being registered. On the MMC subsystem, children
> (new cards) registration starts with the card
> detect IRQ.
>
> Move card detect IRQ disabling to prepare() so that
> no new cards will be registered while we're trying
> to suspend.
>
> Likewise, move card detect IRQ enabling to complete()
> so we only try to register new children after our MMC
> IP is back up.
>
> Signed-off-by: Felipe Balbi <balbi@ti.com>
> ---
>
> Venkat, do you think the patch below makes sense ?
btw, just checked suspend to ram with beagle and panda. We still have
our filesystem after waking up.
ps: you will [1] to test it:
[1] http://marc.info/?l=linux-arm-kernel&m=135090724817604&w=2
> diff --git a/drivers/mmc/host/omap_hsmmc.c b/drivers/mmc/host/omap_hsmmc.c
> index 54bfd0c..4c8b41e 100644
> --- a/drivers/mmc/host/omap_hsmmc.c
> +++ b/drivers/mmc/host/omap_hsmmc.c
> @@ -2022,6 +2022,26 @@ static int __devexit omap_hsmmc_remove(struct platform_device *pdev)
> }
>
> #ifdef CONFIG_PM
> +static int omap_hsmmc_prepare(struct device *dev)
> +{
> + struct omap_hsmmc_host *host = dev_get_drvdata(dev);
> +
> + if (host->pdata->suspend)
> + return host->pdata->suspend(dev, host->slot_id);
> +
> + return 0;
> +}
> +
> +static int omap_hsmmc_complete(struct device *dev)
> +{
> + struct omap_hsmmc_host *host = dev_get_drvdata(dev);
> +
> + if (host->pdata->resume)
> + return host->pdata->resume(dev, host->slot_id);
> +
> + return 0;
> +}
> +
> static int omap_hsmmc_suspend(struct device *dev)
> {
> int ret = 0;
> @@ -2035,23 +2055,10 @@ static int omap_hsmmc_suspend(struct device *dev)
>
> pm_runtime_get_sync(host->dev);
> host->suspended = 1;
> - if (host->pdata->suspend) {
> - ret = host->pdata->suspend(dev, host->slot_id);
> - if (ret) {
> - dev_dbg(dev, "Unable to handle MMC board"
> - " level suspend\n");
> - host->suspended = 0;
> - return ret;
> - }
> - }
> ret = mmc_suspend_host(host->mmc);
>
> if (ret) {
> host->suspended = 0;
> - if (host->pdata->resume) {
> - if (host->pdata->resume(dev, host->slot_id))
> - dev_dbg(dev, "Unmask interrupt failed\n");
> - }
> goto err;
> }
>
> @@ -2088,12 +2095,6 @@ static int omap_hsmmc_resume(struct device *dev)
> if (!(host->mmc->pm_flags & MMC_PM_KEEP_POWER))
> omap_hsmmc_conf_bus_power(host);
>
> - if (host->pdata->resume) {
> - ret = host->pdata->resume(dev, host->slot_id);
> - if (ret)
> - dev_dbg(dev, "Unmask interrupt failed\n");
> - }
> -
> omap_hsmmc_protect_card(host);
>
> /* Notify the core to resume the host */
> @@ -2109,8 +2110,10 @@ static int omap_hsmmc_resume(struct device *dev)
> }
>
> #else
> +#define omap_hsmmc_prepare NULL
> +#define omap_hsmmc_complete NULL
> #define omap_hsmmc_suspend NULL
> -#define omap_hsmmc_resume NULL
> +#define omap_hsmmc_resume NULL
> #endif
>
> static int omap_hsmmc_runtime_suspend(struct device *dev)
> @@ -2138,6 +2141,8 @@ static int omap_hsmmc_runtime_resume(struct device *dev)
> static struct dev_pm_ops omap_hsmmc_dev_pm_ops = {
> .suspend = omap_hsmmc_suspend,
> .resume = omap_hsmmc_resume,
> + .prepare = omap_hsmmc_prepare,
> + .complete = omap_hsmmc_complete,
> .runtime_suspend = omap_hsmmc_runtime_suspend,
> .runtime_resume = omap_hsmmc_runtime_resume,
> };
> --
> 1.8.0.rc0
>
--
balbi
[-- Attachment #2: Digital signature --]
[-- Type: application/pgp-signature, Size: 836 bytes --]
WARNING: multiple messages have this Message-ID (diff)
From: balbi@ti.com (Felipe Balbi)
To: linux-arm-kernel@lists.infradead.org
Subject: [RFC/PATCH] mmc: omap_hsmmc: introduce omap_hsmmc_prepare/complete
Date: Mon, 22 Oct 2012 16:27:08 +0300 [thread overview]
Message-ID: <20121022132708.GA14033@arwen.pp.htv.fi> (raw)
In-Reply-To: <1350910768-8522-1-git-send-email-balbi@ti.com>
On Mon, Oct 22, 2012 at 03:59:28PM +0300, Felipe Balbi wrote:
> prepare() is supposed to prevent new children from
> being registered. On the MMC subsystem, children
> (new cards) registration starts with the card
> detect IRQ.
>
> Move card detect IRQ disabling to prepare() so that
> no new cards will be registered while we're trying
> to suspend.
>
> Likewise, move card detect IRQ enabling to complete()
> so we only try to register new children after our MMC
> IP is back up.
>
> Signed-off-by: Felipe Balbi <balbi@ti.com>
> ---
>
> Venkat, do you think the patch below makes sense ?
btw, just checked suspend to ram with beagle and panda. We still have
our filesystem after waking up.
ps: you will [1] to test it:
[1] http://marc.info/?l=linux-arm-kernel&m=135090724817604&w=2
> diff --git a/drivers/mmc/host/omap_hsmmc.c b/drivers/mmc/host/omap_hsmmc.c
> index 54bfd0c..4c8b41e 100644
> --- a/drivers/mmc/host/omap_hsmmc.c
> +++ b/drivers/mmc/host/omap_hsmmc.c
> @@ -2022,6 +2022,26 @@ static int __devexit omap_hsmmc_remove(struct platform_device *pdev)
> }
>
> #ifdef CONFIG_PM
> +static int omap_hsmmc_prepare(struct device *dev)
> +{
> + struct omap_hsmmc_host *host = dev_get_drvdata(dev);
> +
> + if (host->pdata->suspend)
> + return host->pdata->suspend(dev, host->slot_id);
> +
> + return 0;
> +}
> +
> +static int omap_hsmmc_complete(struct device *dev)
> +{
> + struct omap_hsmmc_host *host = dev_get_drvdata(dev);
> +
> + if (host->pdata->resume)
> + return host->pdata->resume(dev, host->slot_id);
> +
> + return 0;
> +}
> +
> static int omap_hsmmc_suspend(struct device *dev)
> {
> int ret = 0;
> @@ -2035,23 +2055,10 @@ static int omap_hsmmc_suspend(struct device *dev)
>
> pm_runtime_get_sync(host->dev);
> host->suspended = 1;
> - if (host->pdata->suspend) {
> - ret = host->pdata->suspend(dev, host->slot_id);
> - if (ret) {
> - dev_dbg(dev, "Unable to handle MMC board"
> - " level suspend\n");
> - host->suspended = 0;
> - return ret;
> - }
> - }
> ret = mmc_suspend_host(host->mmc);
>
> if (ret) {
> host->suspended = 0;
> - if (host->pdata->resume) {
> - if (host->pdata->resume(dev, host->slot_id))
> - dev_dbg(dev, "Unmask interrupt failed\n");
> - }
> goto err;
> }
>
> @@ -2088,12 +2095,6 @@ static int omap_hsmmc_resume(struct device *dev)
> if (!(host->mmc->pm_flags & MMC_PM_KEEP_POWER))
> omap_hsmmc_conf_bus_power(host);
>
> - if (host->pdata->resume) {
> - ret = host->pdata->resume(dev, host->slot_id);
> - if (ret)
> - dev_dbg(dev, "Unmask interrupt failed\n");
> - }
> -
> omap_hsmmc_protect_card(host);
>
> /* Notify the core to resume the host */
> @@ -2109,8 +2110,10 @@ static int omap_hsmmc_resume(struct device *dev)
> }
>
> #else
> +#define omap_hsmmc_prepare NULL
> +#define omap_hsmmc_complete NULL
> #define omap_hsmmc_suspend NULL
> -#define omap_hsmmc_resume NULL
> +#define omap_hsmmc_resume NULL
> #endif
>
> static int omap_hsmmc_runtime_suspend(struct device *dev)
> @@ -2138,6 +2141,8 @@ static int omap_hsmmc_runtime_resume(struct device *dev)
> static struct dev_pm_ops omap_hsmmc_dev_pm_ops = {
> .suspend = omap_hsmmc_suspend,
> .resume = omap_hsmmc_resume,
> + .prepare = omap_hsmmc_prepare,
> + .complete = omap_hsmmc_complete,
> .runtime_suspend = omap_hsmmc_runtime_suspend,
> .runtime_resume = omap_hsmmc_runtime_resume,
> };
> --
> 1.8.0.rc0
>
--
balbi
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 836 bytes
Desc: Digital signature
URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20121022/88dfd0e5/attachment.sig>
next prev parent reply other threads:[~2012-10-22 13:27 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-10-22 12:59 [RFC/PATCH] mmc: omap_hsmmc: introduce omap_hsmmc_prepare/complete Felipe Balbi
2012-10-22 12:59 ` Felipe Balbi
2012-10-22 13:27 ` Felipe Balbi [this message]
2012-10-22 13:27 ` Felipe Balbi
2012-10-25 18:04 ` Felipe Balbi
2012-10-25 18:04 ` Felipe Balbi
2012-10-26 11:15 ` Venkatraman S
2012-10-26 11:15 ` Venkatraman S
2012-11-06 15:50 ` Venkatraman S
2012-11-06 15:50 ` Venkatraman S
2012-11-06 16:34 ` [PATCH v2] " Felipe Balbi
2012-11-06 16:34 ` Felipe Balbi
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=20121022132708.GA14033@arwen.pp.htv.fi \
--to=balbi@ti.com \
--cc=balajitk@ti.com \
--cc=cjb@laptop.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-mmc@vger.kernel.org \
--cc=linux-omap@vger.kernel.org \
--cc=svenkatr@ti.com \
--cc=tony@atomide.com \
/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: link
Be 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.