soc: rockchip: power-domain: use pm_genpd_remove in error cleanup
authorHeiko Stuebner <heiko@sntech.de>
Thu, 15 Sep 2016 22:14:38 +0000 (00:14 +0200)
committerHeiko Stuebner <heiko@sntech.de>
Fri, 11 Nov 2016 01:14:59 +0000 (02:14 +0100)
The newly introduced pm_genpd_remove reverts the initialization done
by pm_genpd_init and is necessary in the error path of the rockchip
power-domain driver.

Without it the driver will in the error case cleanup the devm-allocated
structures including the elements referenced in the gpd_list thus making
deactivation of unused domains (and probably later genpd accesses as
well) fail by accessing invalid pointers.

Signed-off-by: Heiko Stuebner <heiko@sntech.de>
drivers/soc/rockchip/pm_domains.c

index 988bfd70870623f0f62464bf806c3a583d1cf06d..d36a7351af9de83184cb1a3a104f6cbcd35da0ed 100644 (file)
@@ -479,7 +479,16 @@ err_out:
 
 static void rockchip_pm_remove_one_domain(struct rockchip_pm_domain *pd)
 {
-       int i;
+       int i, ret;
+
+       /*
+        * We're in the error cleanup already, so we only complain,
+        * but won't emit another error on top of the original one.
+        */
+       ret = pm_genpd_remove(&pd->genpd);
+       if (ret < 0)
+               dev_err(pd->pmu->dev, "failed to remove domain '%s' : %d - state may be inconsistent\n",
+                       pd->genpd.name, ret);
 
        for (i = 0; i < pd->num_clks; i++) {
                clk_unprepare(pd->clks[i]);