PM / Domains: Clean up code validating genpd's status
There exists several similar validations of the genpd->status, against GPD_STATE_ACTIVE and GPD_STATE_POWER_OFF. Let's clean up this code by converting to use a helper macro, genpd_status_on(). Signed-off-by: Ulf Hansson <ulf.hansson@linaro.org> Reviewed-by: Viresh Kumar <viresh.kumar@linaro.org> Reviewed-by: Geert Uytterhoeven <geert+renesas@glider.be> Reviewed-by: Bartlomiej Zolnierkiewicz <b.zolnierkie@samsung.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
This commit is contained in:
parent
8ce95844c8
commit
41e2c8e006
|
@ -121,6 +121,7 @@ static const struct genpd_lock_ops genpd_spin_ops = {
|
||||||
#define genpd_lock_interruptible(p) p->lock_ops->lock_interruptible(p)
|
#define genpd_lock_interruptible(p) p->lock_ops->lock_interruptible(p)
|
||||||
#define genpd_unlock(p) p->lock_ops->unlock(p)
|
#define genpd_unlock(p) p->lock_ops->unlock(p)
|
||||||
|
|
||||||
|
#define genpd_status_on(genpd) (genpd->status == GPD_STATE_ACTIVE)
|
||||||
#define genpd_is_irq_safe(genpd) (genpd->flags & GENPD_FLAG_IRQ_SAFE)
|
#define genpd_is_irq_safe(genpd) (genpd->flags & GENPD_FLAG_IRQ_SAFE)
|
||||||
|
|
||||||
static inline bool irq_safe_dev_in_no_sleep_domain(struct device *dev,
|
static inline bool irq_safe_dev_in_no_sleep_domain(struct device *dev,
|
||||||
|
@ -296,8 +297,7 @@ static int genpd_power_off(struct generic_pm_domain *genpd, bool one_dev_on,
|
||||||
* (1) The domain is already in the "power off" state.
|
* (1) The domain is already in the "power off" state.
|
||||||
* (2) System suspend is in progress.
|
* (2) System suspend is in progress.
|
||||||
*/
|
*/
|
||||||
if (genpd->status == GPD_STATE_POWER_OFF
|
if (!genpd_status_on(genpd) || genpd->prepared_count > 0)
|
||||||
|| genpd->prepared_count > 0)
|
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if (atomic_read(&genpd->sd_count) > 0)
|
if (atomic_read(&genpd->sd_count) > 0)
|
||||||
|
@ -373,7 +373,7 @@ static int genpd_power_on(struct generic_pm_domain *genpd, unsigned int depth)
|
||||||
struct gpd_link *link;
|
struct gpd_link *link;
|
||||||
int ret = 0;
|
int ret = 0;
|
||||||
|
|
||||||
if (genpd->status == GPD_STATE_ACTIVE)
|
if (genpd_status_on(genpd))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -752,7 +752,7 @@ static void genpd_sync_power_off(struct generic_pm_domain *genpd, bool use_lock,
|
||||||
{
|
{
|
||||||
struct gpd_link *link;
|
struct gpd_link *link;
|
||||||
|
|
||||||
if (genpd->status == GPD_STATE_POWER_OFF)
|
if (!genpd_status_on(genpd))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (genpd->suspended_count != genpd->device_count
|
if (genpd->suspended_count != genpd->device_count
|
||||||
|
@ -793,7 +793,7 @@ static void genpd_sync_power_on(struct generic_pm_domain *genpd, bool use_lock,
|
||||||
{
|
{
|
||||||
struct gpd_link *link;
|
struct gpd_link *link;
|
||||||
|
|
||||||
if (genpd->status == GPD_STATE_ACTIVE)
|
if (genpd_status_on(genpd))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
list_for_each_entry(link, &genpd->slave_links, slave_node) {
|
list_for_each_entry(link, &genpd->slave_links, slave_node) {
|
||||||
|
@ -1329,8 +1329,7 @@ static int genpd_add_subdomain(struct generic_pm_domain *genpd,
|
||||||
genpd_lock(subdomain);
|
genpd_lock(subdomain);
|
||||||
genpd_lock_nested(genpd, SINGLE_DEPTH_NESTING);
|
genpd_lock_nested(genpd, SINGLE_DEPTH_NESTING);
|
||||||
|
|
||||||
if (genpd->status == GPD_STATE_POWER_OFF
|
if (!genpd_status_on(genpd) && genpd_status_on(subdomain)) {
|
||||||
&& subdomain->status != GPD_STATE_POWER_OFF) {
|
|
||||||
ret = -EINVAL;
|
ret = -EINVAL;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
@ -1346,7 +1345,7 @@ static int genpd_add_subdomain(struct generic_pm_domain *genpd,
|
||||||
list_add_tail(&link->master_node, &genpd->master_links);
|
list_add_tail(&link->master_node, &genpd->master_links);
|
||||||
link->slave = subdomain;
|
link->slave = subdomain;
|
||||||
list_add_tail(&link->slave_node, &subdomain->slave_links);
|
list_add_tail(&link->slave_node, &subdomain->slave_links);
|
||||||
if (subdomain->status != GPD_STATE_POWER_OFF)
|
if (genpd_status_on(subdomain))
|
||||||
genpd_sd_counter_inc(genpd);
|
genpd_sd_counter_inc(genpd);
|
||||||
|
|
||||||
out:
|
out:
|
||||||
|
@ -1406,7 +1405,7 @@ int pm_genpd_remove_subdomain(struct generic_pm_domain *genpd,
|
||||||
list_del(&link->master_node);
|
list_del(&link->master_node);
|
||||||
list_del(&link->slave_node);
|
list_del(&link->slave_node);
|
||||||
kfree(link);
|
kfree(link);
|
||||||
if (subdomain->status != GPD_STATE_POWER_OFF)
|
if (genpd_status_on(subdomain))
|
||||||
genpd_sd_counter_dec(genpd);
|
genpd_sd_counter_dec(genpd);
|
||||||
|
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
@ -2221,7 +2220,7 @@ static int pm_genpd_summary_one(struct seq_file *s,
|
||||||
|
|
||||||
if (WARN_ON(genpd->status >= ARRAY_SIZE(status_lookup)))
|
if (WARN_ON(genpd->status >= ARRAY_SIZE(status_lookup)))
|
||||||
goto exit;
|
goto exit;
|
||||||
if (genpd->status == GPD_STATE_POWER_OFF)
|
if (!genpd_status_on(genpd))
|
||||||
snprintf(state, sizeof(state), "%s-%u",
|
snprintf(state, sizeof(state), "%s-%u",
|
||||||
status_lookup[genpd->status], genpd->state_idx);
|
status_lookup[genpd->status], genpd->state_idx);
|
||||||
else
|
else
|
||||||
|
|
Loading…
Reference in New Issue