[linux-yocto] [PATCH 1/6] Revert "dmaengine: dw: move clock operations to platform.c"

wan.ahmad.zainie.wan.mohamad at intel.com wan.ahmad.zainie.wan.mohamad at intel.com
Mon Nov 16 18:54:13 PST 2015


From: "Ng, Wei Tee" <wei.tee.ng at intel.com>

This reverts commit a2adfa19c6f9adb33e1c11cacf02f0e06e166434.

Signed-off-by: Ng, Wei Tee <wei.tee.ng at intel.com>
---
 drivers/dma/dw/core.c     | 11 +++++++++++
 drivers/dma/dw/internal.h |  2 --
 drivers/dma/dw/platform.c | 25 +++----------------------
 drivers/dma/dw/regs.h     |  1 +
 4 files changed, 15 insertions(+), 24 deletions(-)

diff --git a/drivers/dma/dw/core.c b/drivers/dma/dw/core.c
index 464b585..1030070 100644
--- a/drivers/dma/dw/core.c
+++ b/drivers/dma/dw/core.c
@@ -11,6 +11,7 @@
  */
 
 #include <linux/bitops.h>
+#include <linux/clk.h>
 #include <linux/delay.h>
 #include <linux/dmaengine.h>
 #include <linux/dma-mapping.h>
@@ -1535,6 +1536,11 @@ int dw_dma_probe(struct dw_dma_chip *chip, struct dw_dma_platform_data *pdata)
 	if (!dw)
 		return -ENOMEM;
 
+	dw->clk = devm_clk_get(chip->dev, "hclk");
+	if (IS_ERR(dw->clk))
+		return PTR_ERR(dw->clk);
+	clk_prepare_enable(dw->clk);
+
 	dw->regs = chip->regs;
 	chip->dw = dw;
 
@@ -1695,6 +1701,7 @@ void dw_dma_shutdown(struct dw_dma_chip *chip)
 	struct dw_dma *dw = chip->dw;
 
 	dw_dma_off(dw);
+	clk_disable_unprepare(dw->clk);
 }
 EXPORT_SYMBOL_GPL(dw_dma_shutdown);
 
@@ -1705,6 +1712,8 @@ int dw_dma_suspend(struct dw_dma_chip *chip)
 	struct dw_dma *dw = chip->dw;
 
 	dw_dma_off(dw);
+	clk_disable_unprepare(dw->clk);
+
 	return 0;
 }
 EXPORT_SYMBOL_GPL(dw_dma_suspend);
@@ -1713,7 +1722,9 @@ int dw_dma_resume(struct dw_dma_chip *chip)
 {
 	struct dw_dma *dw = chip->dw;
 
+	clk_prepare_enable(dw->clk);
 	dma_writel(dw, CFG, DW_CFG_DMA_EN);
+
 	return 0;
 }
 EXPORT_SYMBOL_GPL(dw_dma_resume);
diff --git a/drivers/dma/dw/internal.h b/drivers/dma/dw/internal.h
index 34eb09a..43cc1df 100644
--- a/drivers/dma/dw/internal.h
+++ b/drivers/dma/dw/internal.h
@@ -21,14 +21,12 @@
  * @dev:		struct device of the DMA controller
  * @irq:		irq line
  * @regs:		memory mapped I/O space
- * @clk:		hclk clock
  * @dw:			struct dw_dma that is filed by dw_dma_probe()
  */
 struct dw_dma_chip {
 	struct device	*dev;
 	int		irq;
 	void __iomem	*regs;
-	struct clk	*clk;
 	struct dw_dma	*dw;
 };
 
diff --git a/drivers/dma/dw/platform.c b/drivers/dma/dw/platform.c
index 697d004..e35d975 100644
--- a/drivers/dma/dw/platform.c
+++ b/drivers/dma/dw/platform.c
@@ -203,16 +203,9 @@ static int dw_probe(struct platform_device *pdev)
 
 	chip->dev = dev;
 
-	chip->clk = devm_clk_get(chip->dev, "hclk");
-	if (IS_ERR(chip->clk))
-		return PTR_ERR(chip->clk);
-	err = clk_prepare_enable(chip->clk);
-	if (err)
-		return err;
-
 	err = dw_dma_probe(chip, pdata);
 	if (err)
-		goto err_dw_dma_probe;
+		return err;
 
 	platform_set_drvdata(pdev, chip);
 
@@ -228,10 +221,6 @@ static int dw_probe(struct platform_device *pdev)
 		dw_dma_acpi_controller_register(chip->dw);
 
 	return 0;
-
-err_dw_dma_probe:
-	clk_disable_unprepare(chip->clk);
-	return err;
 }
 
 static int dw_remove(struct platform_device *pdev)
@@ -241,10 +230,7 @@ static int dw_remove(struct platform_device *pdev)
 	if (pdev->dev.of_node)
 		of_dma_controller_free(pdev->dev.of_node);
 
-	dw_dma_remove(chip);
-	clk_disable_unprepare(chip->clk);
-
-	return 0;
+	return dw_dma_remove(chip);
 }
 
 static void dw_shutdown(struct platform_device *pdev)
@@ -252,7 +238,6 @@ static void dw_shutdown(struct platform_device *pdev)
 	struct dw_dma_chip *chip = platform_get_drvdata(pdev);
 
 	dw_dma_shutdown(chip);
-	clk_disable_unprepare(chip->clk);
 }
 
 #ifdef CONFIG_OF
@@ -278,10 +263,7 @@ static int dw_suspend_noirq(struct device *dev)
 	struct platform_device *pdev = to_platform_device(dev);
 	struct dw_dma_chip *chip = platform_get_drvdata(pdev);
 
-	dw_dma_suspend(chip);
-	clk_disable_unprepare(chip->clk);
-
-	return 0;
+	return dw_dma_suspend(chip);
 }
 
 static int dw_resume_noirq(struct device *dev)
@@ -289,7 +271,6 @@ static int dw_resume_noirq(struct device *dev)
 	struct platform_device *pdev = to_platform_device(dev);
 	struct dw_dma_chip *chip = platform_get_drvdata(pdev);
 
-	clk_prepare_enable(chip->clk);
 	return dw_dma_resume(chip);
 }
 
diff --git a/drivers/dma/dw/regs.h b/drivers/dma/dw/regs.h
index 1464fa9..f6c2caf 100644
--- a/drivers/dma/dw/regs.h
+++ b/drivers/dma/dw/regs.h
@@ -250,6 +250,7 @@ struct dw_dma {
 	void __iomem		*regs;
 	struct dma_pool		*desc_pool;
 	struct tasklet_struct	tasklet;
+	struct clk		*clk;
 
 	u8			all_chan_mask;
 
-- 
1.9.1



More information about the linux-yocto mailing list