aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/spi
diff options
context:
space:
mode:
authorShubhrajyoti D <shubhrajyoti@ti.com>2011-10-28 07:44:18 -0400
committerGrant Likely <grant.likely@secretlab.ca>2011-10-29 08:07:18 -0400
commit751c925cbb3a270f9771e3945494cb44bd9e732a (patch)
tree8f50cf84164ad01af3e752ba41f90cf14256d956 /drivers/spi
parent2856ac13b8ab41a17b1c65e4eed51543e55f4bac (diff)
spi/omap: call pm_runtime_disable in error path and remove
omap mcspi probe() doesnt call pm_runtime disable functions in case of failure. remove() doesnt call pm_runtime disable. This could lead to warnings as below on subsequent insmod. ~# insmod spi-omap2-mcspi.ko [ 255.383671] omap2_mcspi omap2_mcspi.1: Unbalanced pm_runtime_enable! ... This patch adds the pm_runtime disable() at appropriate stages. Signed-off-by: Hebbar, Gururaja <gururaja.hebbar@ti.com> Signed-off-by: Shubhrajyoti D <shubhrajyoti@ti.com> Signed-off-by: Grant Likely <grant.likely@secretlab.ca>
Diffstat (limited to 'drivers/spi')
-rw-r--r--drivers/spi/spi-omap2-mcspi.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/spi/spi-omap2-mcspi.c b/drivers/spi/spi-omap2-mcspi.c
index 0192d1b79ca7..22e17264a20e 100644
--- a/drivers/spi/spi-omap2-mcspi.c
+++ b/drivers/spi/spi-omap2-mcspi.c
@@ -1196,6 +1196,7 @@ static int __init omap2_mcspi_probe(struct platform_device *pdev)
1196err4: 1196err4:
1197 spi_master_put(master); 1197 spi_master_put(master);
1198err3: 1198err3:
1199 pm_runtime_disable(&pdev->dev);
1199 kfree(mcspi->dma_channels); 1200 kfree(mcspi->dma_channels);
1200err2: 1201err2:
1201 release_mem_region(r->start, resource_size(r)); 1202 release_mem_region(r->start, resource_size(r));
@@ -1217,6 +1218,7 @@ static int __exit omap2_mcspi_remove(struct platform_device *pdev)
1217 dma_channels = mcspi->dma_channels; 1218 dma_channels = mcspi->dma_channels;
1218 1219
1219 omap2_mcspi_disable_clocks(mcspi); 1220 omap2_mcspi_disable_clocks(mcspi);
1221 pm_runtime_disable(&pdev->dev);
1220 r = platform_get_resource(pdev, IORESOURCE_MEM, 0); 1222 r = platform_get_resource(pdev, IORESOURCE_MEM, 0);
1221 release_mem_region(r->start, resource_size(r)); 1223 release_mem_region(r->start, resource_size(r));
1222 1224