soc: rockchip: power-domain: Add regulator support

The power domains are supplied by regulators. Add support for them so
that the regulators are properly turned on before a domain is powered up
and turned off when a domain is powered down.

Change-Id: I43ad569e1b82a8e818cbbf2ffcfa6a965d993bbf
Signed-off-by: Elaine Zhang <zhangqing@rock-chips.com>
This commit is contained in:
Elaine Zhang
2018-10-16 15:26:42 +08:00
committed by Tao Huang
parent 6eb27c4e56
commit 2fa792c706

View File

@@ -19,6 +19,7 @@
#include <linux/clk.h>
#include <linux/regmap.h>
#include <linux/mfd/syscon.h>
#include <linux/regulator/consumer.h>
#include <soc/rockchip/pm_domains.h>
#include <dt-bindings/power/px30-power.h>
#include <dt-bindings/power/rk1808-power.h>
@@ -77,6 +78,7 @@ struct rockchip_pm_domain {
struct clk_bulk_data *clks;
bool is_ignore_pwr;
bool is_qos_saved;
struct regulator *supply;
};
struct rockchip_pmu {
@@ -381,6 +383,21 @@ static int rockchip_pd_power(struct rockchip_pm_domain *pd, bool power_on)
mutex_lock(&pmu->mutex);
if (rockchip_pmu_domain_is_on(pd) != power_on) {
if (IS_ERR_OR_NULL(pd->supply) &&
PTR_ERR(pd->supply) != -ENODEV)
pd->supply = devm_regulator_get_optional(pd->pmu->dev,
genpd->name);
if (power_on && !IS_ERR(pd->supply)) {
ret = regulator_enable(pd->supply);
if (ret < 0) {
dev_err(pd->pmu->dev, "failed to set vdd supply enable '%s',\n",
genpd->name);
mutex_unlock(&pmu->mutex);
return ret;
}
}
ret = clk_bulk_enable(pd->num_clks, pd->clks);
if (ret < 0) {
dev_err(pmu->dev, "failed to enable clocks\n");
@@ -423,6 +440,9 @@ static int rockchip_pd_power(struct rockchip_pm_domain *pd, bool power_on)
out:
clk_bulk_disable(pd->num_clks, pd->clks);
if (!power_on && !IS_ERR(pd->supply))
ret = regulator_disable(pd->supply);
}
mutex_unlock(&pmu->mutex);