diff mbox

[RFC,2/2] mmc: core: sdio: claim host before power up or power off

Message ID 1440411317-8813-2-git-send-email-kishon@ti.com (mailing list archive)
State New, archived
Headers show

Commit Message

Kishon Vijay Abraham I Aug. 24, 2015, 10:15 a.m. UTC
mmc_sdio_runtime_resume and mmc_sdio_runtime_suspend does power up and
power off respectively but does so without claiming the host. Among other
things mmc_claim_host inovkes pm_runtime_get_sync to enable the clocks.
Invoke mmc_claim_host before mmc_power_up and mmc_power_off in
mmc_sdio_runtime_resume and mmc_sdio_runtime_suspend respectively.

This is required since certain platforms (like TI SoCs) access
the controller registers during power up.

Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
---
 drivers/mmc/core/sdio.c |   10 +++++++++-
 1 file changed, 9 insertions(+), 1 deletion(-)

Comments

Ulf Hansson Sept. 11, 2015, 12:45 p.m. UTC | #1
On 24 August 2015 at 12:15, Kishon Vijay Abraham I <kishon@ti.com> wrote:
> mmc_sdio_runtime_resume and mmc_sdio_runtime_suspend does power up and
> power off respectively but does so without claiming the host. Among other
> things mmc_claim_host inovkes pm_runtime_get_sync to enable the clocks.
> Invoke mmc_claim_host before mmc_power_up and mmc_power_off in
> mmc_sdio_runtime_resume and mmc_sdio_runtime_suspend respectively.
>
> This is required since certain platforms (like TI SoCs) access
> the controller registers during power up.

I realize the issue. Actually I have been working on similar patch
which take a bit wider approach. That's because there are more cases
where the host needs to be claimed, when it isn't.

I just posted a patch, please have a look and see if it makes sense to
you, you are on cc.
"[PATCH] mmc: core: Keep host claimed while invoking mmc_power_off|up()"

Kind regards
Uffe

>
> Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
> ---
>  drivers/mmc/core/sdio.c |   10 +++++++++-
>  1 file changed, 9 insertions(+), 1 deletion(-)
>
> diff --git a/drivers/mmc/core/sdio.c b/drivers/mmc/core/sdio.c
> index 0cbbfb8..40795b2 100644
> --- a/drivers/mmc/core/sdio.c
> +++ b/drivers/mmc/core/sdio.c
> @@ -1023,16 +1023,24 @@ static int mmc_sdio_power_restore(struct mmc_host *host)
>
>  static int mmc_sdio_runtime_suspend(struct mmc_host *host)
>  {
> +       mmc_claim_host(host);
>         /* No references to the card, cut the power to it. */
>         mmc_power_off(host);
> +       mmc_release_host(host);
>         return 0;
>  }
>
>  static int mmc_sdio_runtime_resume(struct mmc_host *host)
>  {
> +       int ret;
> +
> +       mmc_claim_host(host);
>         /* Restore power and re-initialize. */
>         mmc_power_up(host, host->card->ocr);
> -       return mmc_sdio_power_restore(host);
> +       ret = _mmc_sdio_power_restore(host);
> +       mmc_release_host(host);
> +
> +       return ret;
>  }
>
>  static int mmc_sdio_reset(struct mmc_host *host)
> --
> 1.7.9.5
>
--
To unsubscribe from this list: send the line "unsubscribe linux-mmc" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Kishon Vijay Abraham I Sept. 11, 2015, 1:17 p.m. UTC | #2
Hi,

On Friday 11 September 2015 06:15 PM, Ulf Hansson wrote:
> On 24 August 2015 at 12:15, Kishon Vijay Abraham I <kishon@ti.com> wrote:
>> mmc_sdio_runtime_resume and mmc_sdio_runtime_suspend does power up and
>> power off respectively but does so without claiming the host. Among other
>> things mmc_claim_host inovkes pm_runtime_get_sync to enable the clocks.
>> Invoke mmc_claim_host before mmc_power_up and mmc_power_off in
>> mmc_sdio_runtime_resume and mmc_sdio_runtime_suspend respectively.
>>
>> This is required since certain platforms (like TI SoCs) access
>> the controller registers during power up.
> 
> I realize the issue. Actually I have been working on similar patch
> which take a bit wider approach. That's because there are more cases
> where the host needs to be claimed, when it isn't.
> 
> I just posted a patch, please have a look and see if it makes sense to
> you, you are on cc.
> "[PATCH] mmc: core: Keep host claimed while invoking mmc_power_off|up()"

Sure Uffe.

-Kishon

> 
> Kind regards
> Uffe
> 
>>
>> Signed-off-by: Kishon Vijay Abraham I <kishon@ti.com>
>> ---
>>  drivers/mmc/core/sdio.c |   10 +++++++++-
>>  1 file changed, 9 insertions(+), 1 deletion(-)
>>
>> diff --git a/drivers/mmc/core/sdio.c b/drivers/mmc/core/sdio.c
>> index 0cbbfb8..40795b2 100644
>> --- a/drivers/mmc/core/sdio.c
>> +++ b/drivers/mmc/core/sdio.c
>> @@ -1023,16 +1023,24 @@ static int mmc_sdio_power_restore(struct mmc_host *host)
>>
>>  static int mmc_sdio_runtime_suspend(struct mmc_host *host)
>>  {
>> +       mmc_claim_host(host);
>>         /* No references to the card, cut the power to it. */
>>         mmc_power_off(host);
>> +       mmc_release_host(host);
>>         return 0;
>>  }
>>
>>  static int mmc_sdio_runtime_resume(struct mmc_host *host)
>>  {
>> +       int ret;
>> +
>> +       mmc_claim_host(host);
>>         /* Restore power and re-initialize. */
>>         mmc_power_up(host, host->card->ocr);
>> -       return mmc_sdio_power_restore(host);
>> +       ret = _mmc_sdio_power_restore(host);
>> +       mmc_release_host(host);
>> +
>> +       return ret;
>>  }
>>
>>  static int mmc_sdio_reset(struct mmc_host *host)
>> --
>> 1.7.9.5
>>
--
To unsubscribe from this list: send the line "unsubscribe linux-mmc" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
diff mbox

Patch

diff --git a/drivers/mmc/core/sdio.c b/drivers/mmc/core/sdio.c
index 0cbbfb8..40795b2 100644
--- a/drivers/mmc/core/sdio.c
+++ b/drivers/mmc/core/sdio.c
@@ -1023,16 +1023,24 @@  static int mmc_sdio_power_restore(struct mmc_host *host)
 
 static int mmc_sdio_runtime_suspend(struct mmc_host *host)
 {
+	mmc_claim_host(host);
 	/* No references to the card, cut the power to it. */
 	mmc_power_off(host);
+	mmc_release_host(host);
 	return 0;
 }
 
 static int mmc_sdio_runtime_resume(struct mmc_host *host)
 {
+	int ret;
+
+	mmc_claim_host(host);
 	/* Restore power and re-initialize. */
 	mmc_power_up(host, host->card->ocr);
-	return mmc_sdio_power_restore(host);
+	ret = _mmc_sdio_power_restore(host);
+	mmc_release_host(host);
+
+	return ret;
 }
 
 static int mmc_sdio_reset(struct mmc_host *host)