aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/base
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/base')
-rw-r--r--drivers/base/power/main.c10
1 files changed, 3 insertions, 7 deletions
diff --git a/drivers/base/power/main.c b/drivers/base/power/main.c
index 83404973f97a..f7a755923751 100644
--- a/drivers/base/power/main.c
+++ b/drivers/base/power/main.c
@@ -669,7 +669,6 @@ static void dpm_complete(pm_message_t state)
669 mutex_unlock(&dpm_list_mtx); 669 mutex_unlock(&dpm_list_mtx);
670 670
671 device_complete(dev, state); 671 device_complete(dev, state);
672 pm_runtime_put_sync(dev);
673 672
674 mutex_lock(&dpm_list_mtx); 673 mutex_lock(&dpm_list_mtx);
675 put_device(dev); 674 put_device(dev);
@@ -1005,12 +1004,9 @@ static int dpm_prepare(pm_message_t state)
1005 if (pm_runtime_barrier(dev) && device_may_wakeup(dev)) 1004 if (pm_runtime_barrier(dev) && device_may_wakeup(dev))
1006 pm_wakeup_event(dev, 0); 1005 pm_wakeup_event(dev, 0);
1007 1006
1008 if (pm_wakeup_pending()) { 1007 pm_runtime_put_sync(dev);
1009 pm_runtime_put_sync(dev); 1008 error = pm_wakeup_pending() ?
1010 error = -EBUSY; 1009 -EBUSY : device_prepare(dev, state);
1011 } else {
1012 error = device_prepare(dev, state);
1013 }
1014 1010
1015 mutex_lock(&dpm_list_mtx); 1011 mutex_lock(&dpm_list_mtx);
1016 if (error) { 1012 if (error) {