Commit 6d8ac9b1 authored by Dmitry Osipenko's avatar Dmitry Osipenko Committed by Mark Brown

ASoC: tegra: ahub: Use clk_bulk helpers

Use clk_bulk helpers to make code cleaner.

Tested-by: Peter Geis <pgwipeout@gmail.com> # Ouya T30 audio works
Tested-by: Matt Merhar <mattmerhar@protonmail.com> # Ouya T30 boot-tested
Tested-by: Dmitry Osipenko <digetx@gmail.com> # Nexus7 T30 audio works
Tested-by: Nicolas Chauvet <kwizart@gmail.com> # TK1 boot-tested
Acked-by: default avatarThierry Reding <treding@nvidia.com>
Signed-off-by: default avatarDmitry Osipenko <digetx@gmail.com>
Link: https://lore.kernel.org/r/20210120003154.26749-6-digetx@gmail.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent 24a41a38
...@@ -45,8 +45,7 @@ static int tegra30_ahub_runtime_suspend(struct device *dev) ...@@ -45,8 +45,7 @@ static int tegra30_ahub_runtime_suspend(struct device *dev)
regcache_cache_only(ahub->regmap_apbif, true); regcache_cache_only(ahub->regmap_apbif, true);
regcache_cache_only(ahub->regmap_ahub, true); regcache_cache_only(ahub->regmap_ahub, true);
clk_disable_unprepare(ahub->clk_apbif); clk_bulk_disable_unprepare(ahub->nclocks, ahub->clocks);
clk_disable_unprepare(ahub->clk_d_audio);
return 0; return 0;
} }
...@@ -66,17 +65,9 @@ static int tegra30_ahub_runtime_resume(struct device *dev) ...@@ -66,17 +65,9 @@ static int tegra30_ahub_runtime_resume(struct device *dev)
{ {
int ret; int ret;
ret = clk_prepare_enable(ahub->clk_d_audio); ret = clk_bulk_prepare_enable(ahub->nclocks, ahub->clocks);
if (ret) { if (ret)
dev_err(dev, "clk_enable d_audio failed: %d\n", ret);
return ret; return ret;
}
ret = clk_prepare_enable(ahub->clk_apbif);
if (ret) {
dev_err(dev, "clk_enable apbif failed: %d\n", ret);
clk_disable(ahub->clk_d_audio);
return ret;
}
regcache_cache_only(ahub->regmap_apbif, false); regcache_cache_only(ahub->regmap_apbif, false);
regcache_cache_only(ahub->regmap_ahub, false); regcache_cache_only(ahub->regmap_ahub, false);
...@@ -559,19 +550,12 @@ static int tegra30_ahub_probe(struct platform_device *pdev) ...@@ -559,19 +550,12 @@ static int tegra30_ahub_probe(struct platform_device *pdev)
ahub->soc_data = soc_data; ahub->soc_data = soc_data;
ahub->dev = &pdev->dev; ahub->dev = &pdev->dev;
ahub->clk_d_audio = devm_clk_get(&pdev->dev, "d_audio"); ahub->clocks[ahub->nclocks++].id = "apbif";
if (IS_ERR(ahub->clk_d_audio)) { ahub->clocks[ahub->nclocks++].id = "d_audio";
dev_err(&pdev->dev, "Can't retrieve ahub d_audio clock\n");
ret = PTR_ERR(ahub->clk_d_audio);
return ret;
}
ahub->clk_apbif = devm_clk_get(&pdev->dev, "apbif"); ret = devm_clk_bulk_get(&pdev->dev, ahub->nclocks, ahub->clocks);
if (IS_ERR(ahub->clk_apbif)) { if (ret)
dev_err(&pdev->dev, "Can't retrieve ahub apbif clock\n");
ret = PTR_ERR(ahub->clk_apbif);
return ret; return ret;
}
res0 = platform_get_resource(pdev, IORESOURCE_MEM, 0); res0 = platform_get_resource(pdev, IORESOURCE_MEM, 0);
regs_apbif = devm_ioremap_resource(&pdev->dev, res0); regs_apbif = devm_ioremap_resource(&pdev->dev, res0);
......
...@@ -511,8 +511,8 @@ struct tegra30_ahub_soc_data { ...@@ -511,8 +511,8 @@ struct tegra30_ahub_soc_data {
struct tegra30_ahub { struct tegra30_ahub {
const struct tegra30_ahub_soc_data *soc_data; const struct tegra30_ahub_soc_data *soc_data;
struct device *dev; struct device *dev;
struct clk *clk_d_audio; struct clk_bulk_data clocks[2];
struct clk *clk_apbif; unsigned int nclocks;
resource_size_t apbif_addr; resource_size_t apbif_addr;
struct regmap *regmap_apbif; struct regmap *regmap_apbif;
struct regmap *regmap_ahub; struct regmap *regmap_ahub;
......
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