Commit 4ac6317a authored by Lucas Stach's avatar Lucas Stach Committed by Shawn Guo

soc: imx: gpcv2: move domain mapping to domain driver probe

As long as the power domain driver is active we want power control
over the domain (which is what the mapping bit requests), so there
is no point in whacking it for every power control action, simply
set the bit in driver probe and clear it when the driver is removed.
Tested-by: default avatarFrieder Schrempf <frieder.schrempf@kontron.de>
Reviewed-by: default avatarFrieder Schrempf <frieder.schrempf@kontron.de>
Signed-off-by: default avatarLucas Stach <l.stach@pengutronix.de>
Signed-off-by: default avatarPeng Fan <peng.fan@nxp.com>
Signed-off-by: default avatarShawn Guo <shawnguo@kernel.org>
parent 4ed57c97
...@@ -140,14 +140,11 @@ static int imx_gpc_pu_pgc_sw_pxx_req(struct generic_pm_domain *genpd, ...@@ -140,14 +140,11 @@ static int imx_gpc_pu_pgc_sw_pxx_req(struct generic_pm_domain *genpd,
int i, ret = 0; int i, ret = 0;
u32 pxx_req; u32 pxx_req;
regmap_update_bits(domain->regmap, GPC_PGC_CPU_MAPPING,
domain->bits.map, domain->bits.map);
if (has_regulator && on) { if (has_regulator && on) {
ret = regulator_enable(domain->regulator); ret = regulator_enable(domain->regulator);
if (ret) { if (ret) {
dev_err(domain->dev, "failed to enable regulator\n"); dev_err(domain->dev, "failed to enable regulator\n");
goto unmap; return ret;
} }
} }
...@@ -203,9 +200,7 @@ static int imx_gpc_pu_pgc_sw_pxx_req(struct generic_pm_domain *genpd, ...@@ -203,9 +200,7 @@ static int imx_gpc_pu_pgc_sw_pxx_req(struct generic_pm_domain *genpd,
/* Preserve earlier error code */ /* Preserve earlier error code */
ret = ret ?: err; ret = ret ?: err;
} }
unmap:
regmap_update_bits(domain->regmap, GPC_PGC_CPU_MAPPING,
domain->bits.map, 0);
return ret; return ret;
} }
...@@ -499,10 +494,13 @@ static int imx_pgc_domain_probe(struct platform_device *pdev) ...@@ -499,10 +494,13 @@ static int imx_pgc_domain_probe(struct platform_device *pdev)
if (ret) if (ret)
return dev_err_probe(domain->dev, ret, "Failed to get domain's clocks\n"); return dev_err_probe(domain->dev, ret, "Failed to get domain's clocks\n");
regmap_update_bits(domain->regmap, GPC_PGC_CPU_MAPPING,
domain->bits.map, domain->bits.map);
ret = pm_genpd_init(&domain->genpd, NULL, true); ret = pm_genpd_init(&domain->genpd, NULL, true);
if (ret) { if (ret) {
dev_err(domain->dev, "Failed to init power domain\n"); dev_err(domain->dev, "Failed to init power domain\n");
goto out_put_clocks; goto out_domain_unmap;
} }
ret = of_genpd_add_provider_simple(domain->dev->of_node, ret = of_genpd_add_provider_simple(domain->dev->of_node,
...@@ -516,7 +514,9 @@ static int imx_pgc_domain_probe(struct platform_device *pdev) ...@@ -516,7 +514,9 @@ static int imx_pgc_domain_probe(struct platform_device *pdev)
out_genpd_remove: out_genpd_remove:
pm_genpd_remove(&domain->genpd); pm_genpd_remove(&domain->genpd);
out_put_clocks: out_domain_unmap:
regmap_update_bits(domain->regmap, GPC_PGC_CPU_MAPPING,
domain->bits.map, 0);
imx_pgc_put_clocks(domain); imx_pgc_put_clocks(domain);
return ret; return ret;
...@@ -528,6 +528,10 @@ static int imx_pgc_domain_remove(struct platform_device *pdev) ...@@ -528,6 +528,10 @@ static int imx_pgc_domain_remove(struct platform_device *pdev)
of_genpd_del_provider(domain->dev->of_node); of_genpd_del_provider(domain->dev->of_node);
pm_genpd_remove(&domain->genpd); pm_genpd_remove(&domain->genpd);
regmap_update_bits(domain->regmap, GPC_PGC_CPU_MAPPING,
domain->bits.map, 0);
imx_pgc_put_clocks(domain); imx_pgc_put_clocks(domain);
return 0; return 0;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment