[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <f861ec6f0907202212h4b28982fjcb9787a3915d7ee7@mail.gmail.com>
Date: Tue, 21 Jul 2009 07:12:11 +0200
From: Manuel Lauss <manuel.lauss@...glemail.com>
To: Frans Pop <elendil@...net.nl>
Cc: linux-kernel@...r.kernel.org, linux-mips@...ux-mips.org,
manuel.lauss@...il.com
Subject: Re: [PATCH] au1xmmc: dev_pm_ops conversion
Good Morning Frans,
On Mon, Jul 20, 2009 at 10:00 PM, Frans Pop<elendil@...net.nl> wrote:
>> Signed-off-by: Manuel Lauss <manuel.lauss@...il.com>
>> ---
>> Run-tested on Au1200.
>>
>> drivers/mmc/host/au1xmmc.c | 23 +++++++++++------------
>> 1 files changed, 11 insertions(+), 12 deletions(-)
>>
>> diff --git a/drivers/mmc/host/au1xmmc.c b/drivers/mmc/host/au1xmmc.c
>> index d3f5561..70509c9 100644
>> --- a/drivers/mmc/host/au1xmmc.c
>> +++ b/drivers/mmc/host/au1xmmc.c
>> @@ -1131,13 +1131,12 @@ static int __devexit au1xmmc_remove(struct
>> platform_device *pdev) return 0;
>> }
>>
>> -#ifdef CONFIG_PM
>
> Won't the removal of this test cause a build failure if CONFIG_PM is not
> set? If the removal of the test is safe, this should IMHO at least be
> explained in the commit message.
No, it builds just fine without CONFIG_PM; it was there to shave off a
few bytes from the kernel image. But not everyone tests this driver
with CONFIG_PM=y, because apparently noone really needed PM on
this platform (Alchemy), and a full build of most of the boards using this
driver fails with PM enabled.
This way the PM methods at least get a compile-test in the non-pm case.
>> -static int au1xmmc_suspend(struct platform_device *pdev, pm_message_t
>> state) +static int au1xmmc_suspend(struct device *dev)
>> {
>> - struct au1xmmc_host *host = platform_get_drvdata(pdev);
>> + struct au1xmmc_host *host = dev_get_drvdata(dev);
>> int ret;
>>
>> - ret = mmc_suspend_host(host->mmc, state);
>> + ret = mmc_suspend_host(host->mmc, PMSG_SUSPEND);
>> if (ret)
>> return ret;
>>
>> @@ -1150,27 +1149,27 @@ static int au1xmmc_suspend(struct
>> platform_device *pdev, pm_message_t state) return 0;
>> }
>>
>> -static int au1xmmc_resume(struct platform_device *pdev)
>> +static int au1xmmc_resume(struct device *dev)
>> {
>> - struct au1xmmc_host *host = platform_get_drvdata(pdev);
>> + struct au1xmmc_host *host = dev_get_drvdata(dev);
>>
>> au1xmmc_reset_controller(host);
>>
>> return mmc_resume_host(host->mmc);
>> }
>> -#else
>> -#define au1xmmc_suspend NULL
>> -#define au1xmmc_resume NULL
>
> ... drop the 3 lines above (as you did) ...
>
>> -#endif
>
> ... move this #endif to after the new struct below ...
>
>> +
>> +static struct dev_pm_ops au1xmmc_pmops = {
>> + .resume = au1xmmc_resume,
>> + .suspend = au1xmmc_suspend,
>> +};
>>
>> static struct platform_driver au1xmmc_driver = {
>> .probe = au1xmmc_probe,
>> .remove = au1xmmc_remove,
>> - .suspend = au1xmmc_suspend,
>> - .resume = au1xmmc_resume,
>> .driver = {
>> .name = DRIVER_NAME,
>> .owner = THIS_MODULE,
>> + .pm = &au1xmmc_pmops,
I like what Magnus Damm did for some of the SuperH drivers:
#ifdef CONFIG_PM
[...]
#define DRIVER_PM_OPS (&driver_pm_ops)
#else
#define DRIVER_PM_OPS NULL
#endif
...
.driver = {
...
.pm = DRIVER_PM_OPS,
}
...
I'd like to keep the pm stuff enabled at all times since it doesn't hurt
in the non-pm case and if kernel size becomes a problem I can add the
#defines back.
What do you think?
Thank you!
Manuel Lauss
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists