diff options
author | Rafael J. Wysocki <rjw@sisk.pl> | 2010-12-24 17:04:06 +0300 |
---|---|---|
committer | Rafael J. Wysocki <rjw@sisk.pl> | 2010-12-24 17:04:06 +0300 |
commit | 4b31db8a16fa0d4d6a0fa42d044e7a4f4dad3641 (patch) | |
tree | 4075d84f26fdd8e70ec62c9b541caa1ea23cebda /drivers/base/power/generic_ops.c | |
parent | 5c1a07ab3e78ef68fc9ccf419c969e8ed88d7cb6 (diff) | |
download | linux-4b31db8a16fa0d4d6a0fa42d044e7a4f4dad3641.tar.xz |
PM / Runtime: Generic resume shouldn't set RPM_ACTIVE unconditionally
The __pm_generic_resume() function changes the given device's runtime
PM status to RPM_ACTIVE if its driver's callback returns 0, but it
only should do that if the rumtime PM is enabled for the device.
Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
Diffstat (limited to 'drivers/base/power/generic_ops.c')
-rw-r--r-- | drivers/base/power/generic_ops.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/base/power/generic_ops.c b/drivers/base/power/generic_ops.c index 3d2c3500069a..42f97f925629 100644 --- a/drivers/base/power/generic_ops.c +++ b/drivers/base/power/generic_ops.c @@ -185,7 +185,7 @@ static int __pm_generic_resume(struct device *dev, int event) return 0; ret = callback(dev); - if (!ret) { + if (!ret && pm_runtime_enabled(dev)) { pm_runtime_disable(dev); pm_runtime_set_active(dev); pm_runtime_enable(dev); |