Commit eaf140b6 authored by Shuah Khan's avatar Shuah Khan Committed by Rafael J. Wysocki

PNP: convert PNP driver bus legacy pm_ops to dev_pm_ops

Convert drivers/pnp/driver.c bus legacy pm_ops to dev_pm_ops using
existing suspend and resume routines.  Add freeze interface to
handle PM_EVENT_FREEZE correctly with dev_pm_ops.  pm_op() looks for
freeze interface when the event is PM_EVENT_FREEZE.
Signed-off-by: default avatarShuah Khan <shuah.kh@samsung.com>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 3b2f64d0
...@@ -154,7 +154,7 @@ static int pnp_bus_match(struct device *dev, struct device_driver *drv) ...@@ -154,7 +154,7 @@ static int pnp_bus_match(struct device *dev, struct device_driver *drv)
return 1; return 1;
} }
static int pnp_bus_suspend(struct device *dev, pm_message_t state) static int __pnp_bus_suspend(struct device *dev, pm_message_t state)
{ {
struct pnp_dev *pnp_dev = to_pnp_dev(dev); struct pnp_dev *pnp_dev = to_pnp_dev(dev);
struct pnp_driver *pnp_drv = pnp_dev->driver; struct pnp_driver *pnp_drv = pnp_dev->driver;
...@@ -180,6 +180,16 @@ static int pnp_bus_suspend(struct device *dev, pm_message_t state) ...@@ -180,6 +180,16 @@ static int pnp_bus_suspend(struct device *dev, pm_message_t state)
return 0; return 0;
} }
static int pnp_bus_suspend(struct device *dev)
{
return __pnp_bus_suspend(dev, PMSG_SUSPEND);
}
static int pnp_bus_freeze(struct device *dev)
{
return __pnp_bus_suspend(dev, PMSG_FREEZE);
}
static int pnp_bus_resume(struct device *dev) static int pnp_bus_resume(struct device *dev)
{ {
struct pnp_dev *pnp_dev = to_pnp_dev(dev); struct pnp_dev *pnp_dev = to_pnp_dev(dev);
...@@ -210,14 +220,19 @@ static int pnp_bus_resume(struct device *dev) ...@@ -210,14 +220,19 @@ static int pnp_bus_resume(struct device *dev)
return 0; return 0;
} }
static const struct dev_pm_ops pnp_bus_dev_pm_ops = {
.suspend = pnp_bus_suspend,
.freeze = pnp_bus_freeze,
.resume = pnp_bus_resume,
};
struct bus_type pnp_bus_type = { struct bus_type pnp_bus_type = {
.name = "pnp", .name = "pnp",
.match = pnp_bus_match, .match = pnp_bus_match,
.probe = pnp_device_probe, .probe = pnp_device_probe,
.remove = pnp_device_remove, .remove = pnp_device_remove,
.shutdown = pnp_device_shutdown, .shutdown = pnp_device_shutdown,
.suspend = pnp_bus_suspend, .pm = &pnp_bus_dev_pm_ops,
.resume = pnp_bus_resume,
.dev_attrs = pnp_interface_attrs, .dev_attrs = pnp_interface_attrs,
}; };
......
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