aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/base/power/domain.c26
1 files changed, 13 insertions, 13 deletions
diff --git a/drivers/base/power/domain.c b/drivers/base/power/domain.c
index c06f8f8717b9..1fc6cc9835ad 100644
--- a/drivers/base/power/domain.c
+++ b/drivers/base/power/domain.c
@@ -1178,36 +1178,36 @@ int pm_genpd_remove_device(struct generic_pm_domain *genpd,
1178/** 1178/**
1179 * pm_genpd_add_subdomain - Add a subdomain to an I/O PM domain. 1179 * pm_genpd_add_subdomain - Add a subdomain to an I/O PM domain.
1180 * @genpd: Master PM domain to add the subdomain to. 1180 * @genpd: Master PM domain to add the subdomain to.
1181 * @new_subdomain: Subdomain to be added. 1181 * @subdomain: Subdomain to be added.
1182 */ 1182 */
1183int pm_genpd_add_subdomain(struct generic_pm_domain *genpd, 1183int pm_genpd_add_subdomain(struct generic_pm_domain *genpd,
1184 struct generic_pm_domain *new_subdomain) 1184 struct generic_pm_domain *subdomain)
1185{ 1185{
1186 struct gpd_link *link; 1186 struct gpd_link *link;
1187 int ret = 0; 1187 int ret = 0;
1188 1188
1189 if (IS_ERR_OR_NULL(genpd) || IS_ERR_OR_NULL(new_subdomain)) 1189 if (IS_ERR_OR_NULL(genpd) || IS_ERR_OR_NULL(subdomain))
1190 return -EINVAL; 1190 return -EINVAL;
1191 1191
1192 start: 1192 start:
1193 genpd_acquire_lock(genpd); 1193 genpd_acquire_lock(genpd);
1194 mutex_lock_nested(&new_subdomain->lock, SINGLE_DEPTH_NESTING); 1194 mutex_lock_nested(&subdomain->lock, SINGLE_DEPTH_NESTING);
1195 1195
1196 if (new_subdomain->status != GPD_STATE_POWER_OFF 1196 if (subdomain->status != GPD_STATE_POWER_OFF
1197 && new_subdomain->status != GPD_STATE_ACTIVE) { 1197 && subdomain->status != GPD_STATE_ACTIVE) {
1198 mutex_unlock(&new_subdomain->lock); 1198 mutex_unlock(&subdomain->lock);
1199 genpd_release_lock(genpd); 1199 genpd_release_lock(genpd);
1200 goto start; 1200 goto start;
1201 } 1201 }
1202 1202
1203 if (genpd->status == GPD_STATE_POWER_OFF 1203 if (genpd->status == GPD_STATE_POWER_OFF
1204 && new_subdomain->status != GPD_STATE_POWER_OFF) { 1204 && subdomain->status != GPD_STATE_POWER_OFF) {
1205 ret = -EINVAL; 1205 ret = -EINVAL;
1206 goto out; 1206 goto out;
1207 } 1207 }
1208 1208
1209 list_for_each_entry(link, &genpd->slave_links, slave_node) { 1209 list_for_each_entry(link, &genpd->slave_links, slave_node) {
1210 if (link->slave == new_subdomain && link->master == genpd) { 1210 if (link->slave == subdomain && link->master == genpd) {
1211 ret = -EINVAL; 1211 ret = -EINVAL;
1212 goto out; 1212 goto out;
1213 } 1213 }
@@ -1220,13 +1220,13 @@ int pm_genpd_add_subdomain(struct generic_pm_domain *genpd,
1220 } 1220 }
1221 link->master = genpd; 1221 link->master = genpd;
1222 list_add_tail(&link->master_node, &genpd->master_links); 1222 list_add_tail(&link->master_node, &genpd->master_links);
1223 link->slave = new_subdomain; 1223 link->slave = subdomain;
1224 list_add_tail(&link->slave_node, &new_subdomain->slave_links); 1224 list_add_tail(&link->slave_node, &subdomain->slave_links);
1225 if (new_subdomain->status != GPD_STATE_POWER_OFF) 1225 if (subdomain->status != GPD_STATE_POWER_OFF)
1226 genpd_sd_counter_inc(genpd); 1226 genpd_sd_counter_inc(genpd);
1227 1227
1228 out: 1228 out:
1229 mutex_unlock(&new_subdomain->lock); 1229 mutex_unlock(&subdomain->lock);
1230 genpd_release_lock(genpd); 1230 genpd_release_lock(genpd);
1231 1231
1232 return ret; 1232 return ret;