ARM / shmobile: Use genpd_queue_power_off_work()
authorRafael J. Wysocki <rjw@sisk.pl>
Thu, 14 Jul 2011 18:59:07 +0000 (20:59 +0200)
committerRafael J. Wysocki <rjw@sisk.pl>
Thu, 14 Jul 2011 18:59:07 +0000 (20:59 +0200)
Make pd_power_down_a3rv() use genpd_queue_power_off_work() to queue
up the powering off of the A4LC domain to avoid queuing it up when
it is pending.

Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl>
Acked-by: Magnus Damm <damm@opensource.se>
arch/arm/mach-shmobile/pm-sh7372.c
drivers/base/power/domain.c
include/linux/pm_domain.h

index f47281a57d43606c5266305b90cacb7173566d8c..0b07138908b7d76207a0c66549bc1eedf6825bc6 100644 (file)
@@ -107,7 +107,7 @@ static int pd_power_down_a3rv(struct generic_pm_domain *genpd)
 
        /* try to power down A4LC after A3RV is requested off */
        pm_genpd_poweron(&sh7372_a4lc.genpd);
-       queue_work(pm_wq, &sh7372_a4lc.genpd.power_off_work);
+       genpd_queue_power_off_work(&sh7372_a4lc.genpd);
 
        return ret;
 }
index c2c537de22b69b07926ae446acf101d34a0e0b1d..00ed4f32a4de72684d37abdecf9269d71411c70f 100644 (file)
@@ -222,7 +222,7 @@ static bool genpd_abort_poweroff(struct generic_pm_domain *genpd)
  * Queue up the execution of pm_genpd_poweroff() unless it's already been done
  * before.
  */
-static void genpd_queue_power_off_work(struct generic_pm_domain *genpd)
+void genpd_queue_power_off_work(struct generic_pm_domain *genpd)
 {
        if (!work_pending(&genpd->power_off_work))
                queue_work(pm_wq, &genpd->power_off_work);
index 3e4f3d308f5e1b51ae988309c490bb82e63bc166..21097cb086fe68c42d1be61f13c9d9c48d8802e8 100644 (file)
@@ -73,6 +73,7 @@ extern void pm_genpd_init(struct generic_pm_domain *genpd,
                          struct dev_power_governor *gov, bool is_off);
 extern int pm_genpd_poweron(struct generic_pm_domain *genpd);
 extern void pm_genpd_poweroff_unused(void);
+extern void genpd_queue_power_off_work(struct generic_pm_domain *genpd);
 #else
 static inline int pm_genpd_add_device(struct generic_pm_domain *genpd,
                                      struct device *dev)
@@ -101,6 +102,7 @@ static inline int pm_genpd_poweron(struct generic_pm_domain *genpd)
        return -ENOSYS;
 }
 static inline void pm_genpd_poweroff_unused(void) {}
+static inline void genpd_queue_power_off_work(struct generic_pm_domain *gpd) {}
 #endif
 
 #endif /* _LINUX_PM_DOMAIN_H */