Commit 639291f2 authored by Shuah Khan's avatar Shuah Khan Committed by Benjamin Herrenschmidt

macintosh/adb: Change platform power management to use dev_pm_ops

Change adb platform driver to register pm ops using dev_pm_ops instead of
legacy pm_ops. .pm hooks call existing legacy suspend and resume interfaces
by passing in the right pm state.
Signed-off-by: default avatarShuah Khan <shuah.kh@samsung.com>
Signed-off-by: default avatarBenjamin Herrenschmidt <benh@kernel.crashing.org>
parent 3c8464a9
...@@ -262,7 +262,7 @@ adb_reset_bus(void) ...@@ -262,7 +262,7 @@ adb_reset_bus(void)
/* /*
* notify clients before sleep * notify clients before sleep
*/ */
static int adb_suspend(struct platform_device *dev, pm_message_t state) static int __adb_suspend(struct platform_device *dev, pm_message_t state)
{ {
adb_got_sleep = 1; adb_got_sleep = 1;
/* We need to get a lock on the probe thread */ /* We need to get a lock on the probe thread */
...@@ -275,10 +275,25 @@ static int adb_suspend(struct platform_device *dev, pm_message_t state) ...@@ -275,10 +275,25 @@ static int adb_suspend(struct platform_device *dev, pm_message_t state)
return 0; return 0;
} }
static int adb_suspend(struct device *dev)
{
return __adb_suspend(to_platform_device(dev), PMSG_SUSPEND);
}
static int adb_freeze(struct device *dev)
{
return __adb_suspend(to_platform_device(dev), PMSG_FREEZE);
}
static int adb_poweroff(struct device *dev)
{
return __adb_suspend(to_platform_device(dev), PMSG_HIBERNATE);
}
/* /*
* reset bus after sleep * reset bus after sleep
*/ */
static int adb_resume(struct platform_device *dev) static int __adb_resume(struct platform_device *dev)
{ {
adb_got_sleep = 0; adb_got_sleep = 0;
up(&adb_probe_mutex); up(&adb_probe_mutex);
...@@ -286,6 +301,11 @@ static int adb_resume(struct platform_device *dev) ...@@ -286,6 +301,11 @@ static int adb_resume(struct platform_device *dev)
return 0; return 0;
} }
static int adb_resume(struct device *dev)
{
return __adb_resume(to_platform_device(dev));
}
#endif /* CONFIG_PM */ #endif /* CONFIG_PM */
static int __init adb_init(void) static int __init adb_init(void)
...@@ -829,14 +849,25 @@ static const struct file_operations adb_fops = { ...@@ -829,14 +849,25 @@ static const struct file_operations adb_fops = {
.release = adb_release, .release = adb_release,
}; };
#ifdef CONFIG_PM
static const struct dev_pm_ops adb_dev_pm_ops = {
.suspend = adb_suspend,
.resume = adb_resume,
/* Hibernate hooks */
.freeze = adb_freeze,
.thaw = adb_resume,
.poweroff = adb_poweroff,
.restore = adb_resume,
};
#endif
static struct platform_driver adb_pfdrv = { static struct platform_driver adb_pfdrv = {
.driver = { .driver = {
.name = "adb", .name = "adb",
},
#ifdef CONFIG_PM #ifdef CONFIG_PM
.suspend = adb_suspend, .pm = &adb_dev_pm_ops,
.resume = adb_resume,
#endif #endif
},
}; };
static struct platform_device adb_pfdev = { static struct platform_device adb_pfdev = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment