]> git.karo-electronics.de Git - linux-beck.git/commitdiff
ASoC: OMAP4: McPDM: Convert to hwmod/omap_device
authorPeter Ujfalusi <peter.ujfalusi@ti.com>
Tue, 2 Aug 2011 11:04:26 +0000 (14:04 +0300)
committerPeter Ujfalusi <peter.ujfalusi@ti.com>
Thu, 22 Sep 2011 06:19:15 +0000 (09:19 +0300)
In order to probe, and operate correctly, the OMAP McPDM driver needs to
be converted to use hwmod.
The device name has been changed to probe the driver.
Replace the clk_* with pm_runtime_* calls to manage the clocks correctly.
Missing request_mem_region/release_mem_region added.

Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com>
Acked-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
Acked-by: Liam Girdwood <lrg@ti.com>
sound/soc/omap/mcpdm.c
sound/soc/omap/mcpdm.h
sound/soc/omap/omap-mcpdm.c
sound/soc/omap/sdp4430.c

index 928f03707451ecde15f046574ed8f1b4e841ee9a..d29cc982b5621844813a794f310a5c294e871499 100644 (file)
@@ -28,7 +28,7 @@
 #include <linux/slab.h>
 #include <linux/interrupt.h>
 #include <linux/err.h>
-#include <linux/clk.h>
+#include <linux/pm_runtime.h>
 #include <linux/delay.h>
 #include <linux/io.h>
 #include <linux/irq.h>
@@ -322,11 +322,11 @@ static irqreturn_t omap_mcpdm_irq_handler(int irq, void *dev_id)
        return IRQ_HANDLED;
 }
 
-int omap_mcpdm_request(void)
+                       int omap_mcpdm_request(void)
 {
        int ret;
 
-       clk_enable(mcpdm->clk);
+       pm_runtime_get_sync(mcpdm->dev);
 
        spin_lock(&mcpdm->lock);
 
@@ -353,7 +353,8 @@ int omap_mcpdm_request(void)
        return 0;
 
 err:
-       clk_disable(mcpdm->clk);
+       mcpdm->free = 1;
+       pm_runtime_put_sync(mcpdm->dev);
        return ret;
 }
 
@@ -368,7 +369,7 @@ void omap_mcpdm_free(void)
        mcpdm->free = 1;
        spin_unlock(&mcpdm->lock);
 
-       clk_disable(mcpdm->clk);
+       pm_runtime_put_sync(mcpdm->dev);
 
        free_irq(mcpdm->irq, (void *)mcpdm);
 }
@@ -421,28 +422,29 @@ int __devinit omap_mcpdm_probe(struct platform_device *pdev)
 
        spin_lock_init(&mcpdm->lock);
        mcpdm->free = 1;
+
+       if (!request_mem_region(res->start, resource_size(res), "McPDM")) {
+               ret = -EBUSY;
+               goto err_resource;
+       }
+
        mcpdm->io_base = ioremap(res->start, resource_size(res));
        if (!mcpdm->io_base) {
                ret = -ENOMEM;
-               goto err_resource;
+               goto err_remap;
        }
 
        mcpdm->irq = platform_get_irq(pdev, 0);
 
-       mcpdm->clk = clk_get(&pdev->dev, "pdm_ck");
-       if (IS_ERR(mcpdm->clk)) {
-               ret = PTR_ERR(mcpdm->clk);
-               dev_err(&pdev->dev, "unable to get pdm_ck: %d\n", ret);
-               goto err_clk;
-       }
-
        mcpdm->dev = &pdev->dev;
        platform_set_drvdata(pdev, mcpdm);
 
+       pm_runtime_enable(mcpdm->dev);
+
        return 0;
 
-err_clk:
-       iounmap(mcpdm->io_base);
+err_remap:
+       release_mem_region(res->start, resource_size(res));
 err_resource:
        kfree(mcpdm);
 exit:
@@ -452,14 +454,16 @@ exit:
 int __devexit omap_mcpdm_remove(struct platform_device *pdev)
 {
        struct omap_mcpdm *mcpdm_ptr = platform_get_drvdata(pdev);
+       struct resource *res;
 
        platform_set_drvdata(pdev, NULL);
 
-       clk_put(mcpdm_ptr->clk);
+       pm_runtime_disable(mcpdm_ptr->dev);
 
        iounmap(mcpdm_ptr->io_base);
+       res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
+       release_mem_region(res->start, resource_size(res));
 
-       mcpdm_ptr->clk = NULL;
        mcpdm_ptr->free = 0;
        mcpdm_ptr->dev = NULL;
 
index df3e16fb51f31ca2c6e1f25c9881ac272f7788c2..b055ad1d3dc23fc59bca9e5c7bcc178893ad0c59 100644 (file)
@@ -131,7 +131,6 @@ struct omap_mcpdm {
 
        spinlock_t lock;
        struct omap_mcpdm_platform_data *pdata;
-       struct clk *clk;
        struct omap_mcpdm_link *downlink;
        struct omap_mcpdm_link *uplink;
        struct completion irq_completion;
index 7727de0c998e9652dc8c9f64bdfb22f94678132f..0820b9ec49076d8b0e6c150877ab017b478c1014 100644 (file)
@@ -254,7 +254,7 @@ static int __devexit asoc_mcpdm_remove(struct platform_device *pdev)
 
 static struct platform_driver asoc_mcpdm_driver = {
        .driver = {
-                       .name = "omap-mcpdm-dai",
+                       .name = "omap-mcpdm",
                        .owner = THIS_MODULE,
        },
 
index b80efb02bfcae81ea365fce6c9f0be93a63dde28..32782b96c3e4d07c802827e225b676058b0faaa1 100644 (file)
@@ -165,7 +165,7 @@ static int sdp4430_twl6040_init(struct snd_soc_pcm_runtime *rtd)
 static struct snd_soc_dai_link sdp4430_dai = {
        .name = "TWL6040",
        .stream_name = "TWL6040",
-       .cpu_dai_name ="omap-mcpdm-dai",
+       .cpu_dai_name = "omap-mcpdm",
        .codec_dai_name = "twl6040-hifi",
        .platform_name = "omap-pcm-audio",
        .codec_name = "twl6040-codec",