Commit 939941d4 authored by Mark Brown's avatar Mark Brown Committed by Samuel Ortiz

mfd: Convert pcf50633 to dev_pm_ops

There is a move to deprecate bus-specific PM operations and move to
using dev_pm_ops instead in order to reduce the amount of boilerplate
code in buses and facilitiate updates to the PM core. Do this move for
the pcf50633 driver.
Signed-off-by: default avatarMark Brown <broonie@opensource.wolfsonmicro.com>
Signed-off-by: default avatarSamuel Ortiz <sameo@linux.intel.com>
parent 44be0a40
...@@ -21,6 +21,7 @@ ...@@ -21,6 +21,7 @@
#include <linux/workqueue.h> #include <linux/workqueue.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/i2c.h> #include <linux/i2c.h>
#include <linux/pm.h>
#include <linux/slab.h> #include <linux/slab.h>
#include <linux/mfd/pcf50633/core.h> #include <linux/mfd/pcf50633/core.h>
...@@ -230,27 +231,26 @@ pcf50633_client_dev_register(struct pcf50633 *pcf, const char *name, ...@@ -230,27 +231,26 @@ pcf50633_client_dev_register(struct pcf50633 *pcf, const char *name,
} }
} }
#ifdef CONFIG_PM #ifdef CONFIG_PM_SLEEP
static int pcf50633_suspend(struct i2c_client *client, pm_message_t state) static int pcf50633_suspend(struct device *dev)
{ {
struct pcf50633 *pcf; struct i2c_client *client = to_i2c_client(dev);
pcf = i2c_get_clientdata(client); struct pcf50633 *pcf = i2c_get_clientdata(client);
return pcf50633_irq_suspend(pcf); return pcf50633_irq_suspend(pcf);
} }
static int pcf50633_resume(struct i2c_client *client) static int pcf50633_resume(struct device *dev)
{ {
struct pcf50633 *pcf; struct i2c_client *client = to_i2c_client(dev);
pcf = i2c_get_clientdata(client); struct pcf50633 *pcf = i2c_get_clientdata(client);
return pcf50633_irq_resume(pcf); return pcf50633_irq_resume(pcf);
} }
#else
#define pcf50633_suspend NULL
#define pcf50633_resume NULL
#endif #endif
static SIMPLE_DEV_PM_OPS(pcf50633_pm, pcf50633_suspend, pcf50633_resume);
static int __devinit pcf50633_probe(struct i2c_client *client, static int __devinit pcf50633_probe(struct i2c_client *client,
const struct i2c_device_id *ids) const struct i2c_device_id *ids)
{ {
...@@ -364,12 +364,11 @@ static struct i2c_device_id pcf50633_id_table[] = { ...@@ -364,12 +364,11 @@ static struct i2c_device_id pcf50633_id_table[] = {
static struct i2c_driver pcf50633_driver = { static struct i2c_driver pcf50633_driver = {
.driver = { .driver = {
.name = "pcf50633", .name = "pcf50633",
.pm = &pcf50633_pm,
}, },
.id_table = pcf50633_id_table, .id_table = pcf50633_id_table,
.probe = pcf50633_probe, .probe = pcf50633_probe,
.remove = __devexit_p(pcf50633_remove), .remove = __devexit_p(pcf50633_remove),
.suspend = pcf50633_suspend,
.resume = pcf50633_resume,
}; };
static int __init pcf50633_init(void) static int __init pcf50633_init(void)
......
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