Commit f6ed6491 authored by Sameer Pujar's avatar Sameer Pujar Committed by Vinod Koul

dmaengine: tegra210-adma: use devm_clk_*() helpers

adma driver is using pm_clk_*() interface for managing clock resources.
With this it is observed that clocks remain ON always. This happens on
Tegra devices which use BPMP co-processor to manage clock resources,
where clocks are enabled during prepare phase. This is necessary because
clocks to BPMP are always blocking. When pm_clk_*() interface is used on
such Tegra devices, clock prepare count is not balanced till remove call
happens for the driver and hence clocks are seen ON always. Thus this
patch replaces pm_clk_*() with devm_clk_*() framework.
Suggested-by: default avatarMohan Kumar D <mkumard@nvidia.com>
Reviewed-by: default avatarJonathan Hunter <jonathanh@nvidia.com>
Signed-off-by: default avatarSameer Pujar <spujar@nvidia.com>
Signed-off-by: default avatarVinod Koul <vkoul@kernel.org>
parent 5ba846b1
...@@ -22,7 +22,6 @@ ...@@ -22,7 +22,6 @@
#include <linux/of_device.h> #include <linux/of_device.h>
#include <linux/of_dma.h> #include <linux/of_dma.h>
#include <linux/of_irq.h> #include <linux/of_irq.h>
#include <linux/pm_clock.h>
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <linux/slab.h> #include <linux/slab.h>
...@@ -141,6 +140,7 @@ struct tegra_adma { ...@@ -141,6 +140,7 @@ struct tegra_adma {
struct dma_device dma_dev; struct dma_device dma_dev;
struct device *dev; struct device *dev;
void __iomem *base_addr; void __iomem *base_addr;
struct clk *ahub_clk;
unsigned int nr_channels; unsigned int nr_channels;
unsigned long rx_requests_reserved; unsigned long rx_requests_reserved;
unsigned long tx_requests_reserved; unsigned long tx_requests_reserved;
...@@ -637,8 +637,9 @@ static int tegra_adma_runtime_suspend(struct device *dev) ...@@ -637,8 +637,9 @@ static int tegra_adma_runtime_suspend(struct device *dev)
struct tegra_adma *tdma = dev_get_drvdata(dev); struct tegra_adma *tdma = dev_get_drvdata(dev);
tdma->global_cmd = tdma_read(tdma, ADMA_GLOBAL_CMD); tdma->global_cmd = tdma_read(tdma, ADMA_GLOBAL_CMD);
clk_disable_unprepare(tdma->ahub_clk);
return pm_clk_suspend(dev); return 0;
} }
static int tegra_adma_runtime_resume(struct device *dev) static int tegra_adma_runtime_resume(struct device *dev)
...@@ -646,10 +647,11 @@ static int tegra_adma_runtime_resume(struct device *dev) ...@@ -646,10 +647,11 @@ static int tegra_adma_runtime_resume(struct device *dev)
struct tegra_adma *tdma = dev_get_drvdata(dev); struct tegra_adma *tdma = dev_get_drvdata(dev);
int ret; int ret;
ret = pm_clk_resume(dev); ret = clk_prepare_enable(tdma->ahub_clk);
if (ret) if (ret) {
dev_err(dev, "ahub clk_enable failed: %d\n", ret);
return ret; return ret;
}
tdma_write(tdma, ADMA_GLOBAL_CMD, tdma->global_cmd); tdma_write(tdma, ADMA_GLOBAL_CMD, tdma->global_cmd);
return 0; return 0;
...@@ -693,13 +695,11 @@ static int tegra_adma_probe(struct platform_device *pdev) ...@@ -693,13 +695,11 @@ static int tegra_adma_probe(struct platform_device *pdev)
if (IS_ERR(tdma->base_addr)) if (IS_ERR(tdma->base_addr))
return PTR_ERR(tdma->base_addr); return PTR_ERR(tdma->base_addr);
ret = pm_clk_create(&pdev->dev); tdma->ahub_clk = devm_clk_get(&pdev->dev, "d_audio");
if (ret) if (IS_ERR(tdma->ahub_clk)) {
return ret; dev_err(&pdev->dev, "Error: Missing ahub controller clock\n");
return PTR_ERR(tdma->ahub_clk);
ret = of_pm_clk_add_clk(&pdev->dev, "d_audio"); }
if (ret)
goto clk_destroy;
pm_runtime_enable(&pdev->dev); pm_runtime_enable(&pdev->dev);
...@@ -776,8 +776,6 @@ static int tegra_adma_probe(struct platform_device *pdev) ...@@ -776,8 +776,6 @@ static int tegra_adma_probe(struct platform_device *pdev)
pm_runtime_put_sync(&pdev->dev); pm_runtime_put_sync(&pdev->dev);
rpm_disable: rpm_disable:
pm_runtime_disable(&pdev->dev); pm_runtime_disable(&pdev->dev);
clk_destroy:
pm_clk_destroy(&pdev->dev);
return ret; return ret;
} }
...@@ -794,7 +792,6 @@ static int tegra_adma_remove(struct platform_device *pdev) ...@@ -794,7 +792,6 @@ static int tegra_adma_remove(struct platform_device *pdev)
pm_runtime_put_sync(&pdev->dev); pm_runtime_put_sync(&pdev->dev);
pm_runtime_disable(&pdev->dev); pm_runtime_disable(&pdev->dev);
pm_clk_destroy(&pdev->dev);
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