* [PATCH] input: add suspend wakeup support to sh_keysc
@ 2009-03-10 6:24 Magnus Damm
2009-03-10 8:24 ` Trilok Soni
0 siblings, 1 reply; 5+ messages in thread
From: Magnus Damm @ 2009-03-10 6:24 UTC (permalink / raw)
To: linux-input; +Cc: Magnus Damm, lethal, linux-sh
From: Magnus Damm <damm@igel.co.jp>
This patch adds wakeup support to the sh_keysc driver.
With this feature the ".../power/wakeup" file can be
used to enable and disable if the device takes the
system out of suspend. Default is enabled.
Signed-off-by: Magnus Damm <damm@igel.co.jp>
---
drivers/input/keyboard/sh_keysc.c | 29 +++++++++++++++++++++++++----
1 file changed, 25 insertions(+), 4 deletions(-)
--- 0001/drivers/input/keyboard/sh_keysc.c
+++ work/drivers/input/keyboard/sh_keysc.c 2009-03-09 19:14:47.000000000 +0900
@@ -219,6 +219,8 @@ static int __devinit sh_keysc_probe(stru
pdata->scan_timing, priv->iomem_base + KYCR1_OFFS);
iowrite16(0, priv->iomem_base + KYOUTDR_OFFS);
iowrite16(KYCR2_IRQ_LEVEL, priv->iomem_base + KYCR2_OFFS);
+
+ device_init_wakeup(&pdev->dev, 1);
return 0;
err5:
free_irq(irq, pdev);
@@ -253,17 +255,36 @@ static int __devexit sh_keysc_remove(str
return 0;
}
+static int sh_keysc_suspend(struct device *dev)
+{
+ struct platform_device *pdev;
+ struct sh_keysc_priv *priv;
+ unsigned short value;
+
+ pdev = container_of(dev, struct platform_device, dev);
+ priv = platform_get_drvdata(pdev);
+
+ value = ioread16(priv->iomem_base + KYCR1_OFFS);
+
+ if (device_may_wakeup(dev))
+ value |= 0x80;
+ else
+ value &= ~0x80;
-#define sh_keysc_suspend NULL
-#define sh_keysc_resume NULL
+ iowrite16(value, priv->iomem_base + KYCR1_OFFS);
+ return 0;
+}
+
+static struct dev_pm_ops sh_keysc_dev_pm_ops = {
+ .suspend = sh_keysc_suspend,
+};
struct platform_driver sh_keysc_device_driver = {
.probe = sh_keysc_probe,
.remove = __devexit_p(sh_keysc_remove),
- .suspend = sh_keysc_suspend,
- .resume = sh_keysc_resume,
.driver = {
.name = "sh_keysc",
+ .pm = &sh_keysc_dev_pm_ops,
}
};
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] input: add suspend wakeup support to sh_keysc
2009-03-10 6:24 [PATCH] input: add suspend wakeup support to sh_keysc Magnus Damm
@ 2009-03-10 8:24 ` Trilok Soni
2009-03-10 10:01 ` Magnus Damm
0 siblings, 1 reply; 5+ messages in thread
From: Trilok Soni @ 2009-03-10 8:24 UTC (permalink / raw)
To: Magnus Damm; +Cc: linux-input, lethal, linux-sh
Hi Magnus,
> +
> + device_init_wakeup(&pdev->dev, 1);
> return 0;
Please add device_init_wakeup(&pdev->dev, 0) in sh_keysc_remove.
> err5:
> free_irq(irq, pdev);
> @@ -253,17 +255,36 @@ static int __devexit sh_keysc_remove(str
> return 0;
> }
>
> +static int sh_keysc_suspend(struct device *dev)
> +{
> + struct platform_device *pdev;
> + struct sh_keysc_priv *priv;
> + unsigned short value;
> +
> + pdev = container_of(dev, struct platform_device, dev);
> + priv = platform_get_drvdata(pdev);
to_platform_device(...) ?
--
---Trilok Soni
http://triloksoni.wordpress.com
http://www.linkedin.com/in/triloksoni
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH] input: add suspend wakeup support to sh_keysc
2009-03-10 8:24 ` Trilok Soni
@ 2009-03-10 10:01 ` Magnus Damm
2009-03-10 10:43 ` Trilok Soni
0 siblings, 1 reply; 5+ messages in thread
From: Magnus Damm @ 2009-03-10 10:01 UTC (permalink / raw)
To: Trilok Soni; +Cc: linux-input, lethal, linux-sh
Hi Trilok,
Thanks for your comments!
On Tue, Mar 10, 2009 at 5:24 PM, Trilok Soni <soni.trilok@gmail.com> wrote:
> Hi Magnus,
>
>> +
>> + device_init_wakeup(&pdev->dev, 1);
>> return 0;
>
>
> Please add device_init_wakeup(&pdev->dev, 0) in sh_keysc_remove.
Isn't this just flagging the device as wakeup capable? My first guess
would be that the the wakeup state of a removed device is irrelevant
since it won't be suspended anyway. Or am I misunderstanding? Please
explain in more detail.
>> err5:
>> free_irq(irq, pdev);
>> @@ -253,17 +255,36 @@ static int __devexit sh_keysc_remove(str
>> return 0;
>> }
>>
>> +static int sh_keysc_suspend(struct device *dev)
>> +{
>> + struct platform_device *pdev;
>> + struct sh_keysc_priv *priv;
>> + unsigned short value;
>> +
>> + pdev = container_of(dev, struct platform_device, dev);
>> + priv = platform_get_drvdata(pdev);
>
> to_platform_device(...) ?
Thanks, much better!
/ magnus
--
To unsubscribe from this list: send the line "unsubscribe linux-input" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2009-03-10 11:10 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-03-10 6:24 [PATCH] input: add suspend wakeup support to sh_keysc Magnus Damm
2009-03-10 8:24 ` Trilok Soni
2009-03-10 10:01 ` Magnus Damm
2009-03-10 10:43 ` Trilok Soni
[not found] ` <aec7e5c30903100352o611e6cake0ddd50fed1d6975@mail.gmail.com>
2009-03-10 11:10 ` Trilok Soni
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).