diff options
author | Peter Ujfalusi <peter.ujfalusi@ti.com> | 2011-08-02 07:04:26 -0400 |
---|---|---|
committer | Peter Ujfalusi <peter.ujfalusi@ti.com> | 2011-09-22 02:19:15 -0400 |
commit | 3a98cd6b2b0459de4ebf85356fbcc34b9848b58a (patch) | |
tree | 9c98c903165c37cb0a68cf958d46822c89362f5f | |
parent | b199adfdff98092b16f67860013fb5263579c476 (diff) |
ASoC: OMAP4: McPDM: Convert to hwmod/omap_device
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>
-rw-r--r-- | sound/soc/omap/mcpdm.c | 38 | ||||
-rw-r--r-- | sound/soc/omap/mcpdm.h | 1 | ||||
-rw-r--r-- | sound/soc/omap/omap-mcpdm.c | 2 | ||||
-rw-r--r-- | sound/soc/omap/sdp4430.c | 2 |
4 files changed, 23 insertions, 20 deletions
diff --git a/sound/soc/omap/mcpdm.c b/sound/soc/omap/mcpdm.c index 928f03707451..d29cc982b562 100644 --- a/sound/soc/omap/mcpdm.c +++ b/sound/soc/omap/mcpdm.c | |||
@@ -28,7 +28,7 @@ | |||
28 | #include <linux/slab.h> | 28 | #include <linux/slab.h> |
29 | #include <linux/interrupt.h> | 29 | #include <linux/interrupt.h> |
30 | #include <linux/err.h> | 30 | #include <linux/err.h> |
31 | #include <linux/clk.h> | 31 | #include <linux/pm_runtime.h> |
32 | #include <linux/delay.h> | 32 | #include <linux/delay.h> |
33 | #include <linux/io.h> | 33 | #include <linux/io.h> |
34 | #include <linux/irq.h> | 34 | #include <linux/irq.h> |
@@ -322,11 +322,11 @@ static irqreturn_t omap_mcpdm_irq_handler(int irq, void *dev_id) | |||
322 | return IRQ_HANDLED; | 322 | return IRQ_HANDLED; |
323 | } | 323 | } |
324 | 324 | ||
325 | int omap_mcpdm_request(void) | 325 | int omap_mcpdm_request(void) |
326 | { | 326 | { |
327 | int ret; | 327 | int ret; |
328 | 328 | ||
329 | clk_enable(mcpdm->clk); | 329 | pm_runtime_get_sync(mcpdm->dev); |
330 | 330 | ||
331 | spin_lock(&mcpdm->lock); | 331 | spin_lock(&mcpdm->lock); |
332 | 332 | ||
@@ -353,7 +353,8 @@ int omap_mcpdm_request(void) | |||
353 | return 0; | 353 | return 0; |
354 | 354 | ||
355 | err: | 355 | err: |
356 | clk_disable(mcpdm->clk); | 356 | mcpdm->free = 1; |
357 | pm_runtime_put_sync(mcpdm->dev); | ||
357 | return ret; | 358 | return ret; |
358 | } | 359 | } |
359 | 360 | ||
@@ -368,7 +369,7 @@ void omap_mcpdm_free(void) | |||
368 | mcpdm->free = 1; | 369 | mcpdm->free = 1; |
369 | spin_unlock(&mcpdm->lock); | 370 | spin_unlock(&mcpdm->lock); |
370 | 371 | ||
371 | clk_disable(mcpdm->clk); | 372 | pm_runtime_put_sync(mcpdm->dev); |
372 | 373 | ||
373 | free_irq(mcpdm->irq, (void *)mcpdm); | 374 | free_irq(mcpdm->irq, (void *)mcpdm); |
374 | } | 375 | } |
@@ -421,28 +422,29 @@ int __devinit omap_mcpdm_probe(struct platform_device *pdev) | |||
421 | 422 | ||
422 | spin_lock_init(&mcpdm->lock); | 423 | spin_lock_init(&mcpdm->lock); |
423 | mcpdm->free = 1; | 424 | mcpdm->free = 1; |
425 | |||
426 | if (!request_mem_region(res->start, resource_size(res), "McPDM")) { | ||
427 | ret = -EBUSY; | ||
428 | goto err_resource; | ||
429 | } | ||
430 | |||
424 | mcpdm->io_base = ioremap(res->start, resource_size(res)); | 431 | mcpdm->io_base = ioremap(res->start, resource_size(res)); |
425 | if (!mcpdm->io_base) { | 432 | if (!mcpdm->io_base) { |
426 | ret = -ENOMEM; | 433 | ret = -ENOMEM; |
427 | goto err_resource; | 434 | goto err_remap; |
428 | } | 435 | } |
429 | 436 | ||
430 | mcpdm->irq = platform_get_irq(pdev, 0); | 437 | mcpdm->irq = platform_get_irq(pdev, 0); |
431 | 438 | ||
432 | mcpdm->clk = clk_get(&pdev->dev, "pdm_ck"); | ||
433 | if (IS_ERR(mcpdm->clk)) { | ||
434 | ret = PTR_ERR(mcpdm->clk); | ||
435 | dev_err(&pdev->dev, "unable to get pdm_ck: %d\n", ret); | ||
436 | goto err_clk; | ||
437 | } | ||
438 | |||
439 | mcpdm->dev = &pdev->dev; | 439 | mcpdm->dev = &pdev->dev; |
440 | platform_set_drvdata(pdev, mcpdm); | 440 | platform_set_drvdata(pdev, mcpdm); |
441 | 441 | ||
442 | pm_runtime_enable(mcpdm->dev); | ||
443 | |||
442 | return 0; | 444 | return 0; |
443 | 445 | ||
444 | err_clk: | 446 | err_remap: |
445 | iounmap(mcpdm->io_base); | 447 | release_mem_region(res->start, resource_size(res)); |
446 | err_resource: | 448 | err_resource: |
447 | kfree(mcpdm); | 449 | kfree(mcpdm); |
448 | exit: | 450 | exit: |
@@ -452,14 +454,16 @@ exit: | |||
452 | int __devexit omap_mcpdm_remove(struct platform_device *pdev) | 454 | int __devexit omap_mcpdm_remove(struct platform_device *pdev) |
453 | { | 455 | { |
454 | struct omap_mcpdm *mcpdm_ptr = platform_get_drvdata(pdev); | 456 | struct omap_mcpdm *mcpdm_ptr = platform_get_drvdata(pdev); |
457 | struct resource *res; | ||
455 | 458 | ||
456 | platform_set_drvdata(pdev, NULL); | 459 | platform_set_drvdata(pdev, NULL); |
457 | 460 | ||
458 | clk_put(mcpdm_ptr->clk); | 461 | pm_runtime_disable(mcpdm_ptr->dev); |
459 | 462 | ||
460 | iounmap(mcpdm_ptr->io_base); | 463 | iounmap(mcpdm_ptr->io_base); |
464 | res = platform_get_resource(pdev, IORESOURCE_MEM, 0); | ||
465 | release_mem_region(res->start, resource_size(res)); | ||
461 | 466 | ||
462 | mcpdm_ptr->clk = NULL; | ||
463 | mcpdm_ptr->free = 0; | 467 | mcpdm_ptr->free = 0; |
464 | mcpdm_ptr->dev = NULL; | 468 | mcpdm_ptr->dev = NULL; |
465 | 469 | ||
diff --git a/sound/soc/omap/mcpdm.h b/sound/soc/omap/mcpdm.h index df3e16fb51f3..b055ad1d3dc2 100644 --- a/sound/soc/omap/mcpdm.h +++ b/sound/soc/omap/mcpdm.h | |||
@@ -131,7 +131,6 @@ struct omap_mcpdm { | |||
131 | 131 | ||
132 | spinlock_t lock; | 132 | spinlock_t lock; |
133 | struct omap_mcpdm_platform_data *pdata; | 133 | struct omap_mcpdm_platform_data *pdata; |
134 | struct clk *clk; | ||
135 | struct omap_mcpdm_link *downlink; | 134 | struct omap_mcpdm_link *downlink; |
136 | struct omap_mcpdm_link *uplink; | 135 | struct omap_mcpdm_link *uplink; |
137 | struct completion irq_completion; | 136 | struct completion irq_completion; |
diff --git a/sound/soc/omap/omap-mcpdm.c b/sound/soc/omap/omap-mcpdm.c index 7727de0c998e..0820b9ec4907 100644 --- a/sound/soc/omap/omap-mcpdm.c +++ b/sound/soc/omap/omap-mcpdm.c | |||
@@ -254,7 +254,7 @@ static int __devexit asoc_mcpdm_remove(struct platform_device *pdev) | |||
254 | 254 | ||
255 | static struct platform_driver asoc_mcpdm_driver = { | 255 | static struct platform_driver asoc_mcpdm_driver = { |
256 | .driver = { | 256 | .driver = { |
257 | .name = "omap-mcpdm-dai", | 257 | .name = "omap-mcpdm", |
258 | .owner = THIS_MODULE, | 258 | .owner = THIS_MODULE, |
259 | }, | 259 | }, |
260 | 260 | ||
diff --git a/sound/soc/omap/sdp4430.c b/sound/soc/omap/sdp4430.c index b80efb02bfca..32782b96c3e4 100644 --- a/sound/soc/omap/sdp4430.c +++ b/sound/soc/omap/sdp4430.c | |||
@@ -165,7 +165,7 @@ static int sdp4430_twl6040_init(struct snd_soc_pcm_runtime *rtd) | |||
165 | static struct snd_soc_dai_link sdp4430_dai = { | 165 | static struct snd_soc_dai_link sdp4430_dai = { |
166 | .name = "TWL6040", | 166 | .name = "TWL6040", |
167 | .stream_name = "TWL6040", | 167 | .stream_name = "TWL6040", |
168 | .cpu_dai_name ="omap-mcpdm-dai", | 168 | .cpu_dai_name = "omap-mcpdm", |
169 | .codec_dai_name = "twl6040-hifi", | 169 | .codec_dai_name = "twl6040-hifi", |
170 | .platform_name = "omap-pcm-audio", | 170 | .platform_name = "omap-pcm-audio", |
171 | .codec_name = "twl6040-codec", | 171 | .codec_name = "twl6040-codec", |