|
|
@@ -1388,12 +1388,12 @@ static int genpd_add_device(struct generic_pm_domain *genpd, struct device *dev,
|
|
|
if (IS_ERR(gpd_data))
|
|
|
return PTR_ERR(gpd_data);
|
|
|
|
|
|
- genpd_lock(genpd);
|
|
|
-
|
|
|
ret = genpd->attach_dev ? genpd->attach_dev(genpd, dev) : 0;
|
|
|
if (ret)
|
|
|
goto out;
|
|
|
|
|
|
+ genpd_lock(genpd);
|
|
|
+
|
|
|
dev_pm_domain_set(dev, &genpd->domain);
|
|
|
|
|
|
genpd->device_count++;
|
|
|
@@ -1401,9 +1401,8 @@ static int genpd_add_device(struct generic_pm_domain *genpd, struct device *dev,
|
|
|
|
|
|
list_add_tail(&gpd_data->base.list_node, &genpd->dev_list);
|
|
|
|
|
|
- out:
|
|
|
genpd_unlock(genpd);
|
|
|
-
|
|
|
+ out:
|
|
|
if (ret)
|
|
|
genpd_free_dev_data(dev, gpd_data);
|
|
|
else
|
|
|
@@ -1452,15 +1451,15 @@ static int genpd_remove_device(struct generic_pm_domain *genpd,
|
|
|
genpd->device_count--;
|
|
|
genpd->max_off_time_changed = true;
|
|
|
|
|
|
- if (genpd->detach_dev)
|
|
|
- genpd->detach_dev(genpd, dev);
|
|
|
-
|
|
|
dev_pm_domain_set(dev, NULL);
|
|
|
|
|
|
list_del_init(&pdd->list_node);
|
|
|
|
|
|
genpd_unlock(genpd);
|
|
|
|
|
|
+ if (genpd->detach_dev)
|
|
|
+ genpd->detach_dev(genpd, dev);
|
|
|
+
|
|
|
genpd_free_dev_data(dev, gpd_data);
|
|
|
|
|
|
return 0;
|