dmaengine: zxdma: explicitly free irq on device removal
authorVinod Koul <vinod.koul@intel.com>
Mon, 18 May 2015 10:03:13 +0000 (15:33 +0530)
committerVinod Koul <vinod.koul@intel.com>
Thu, 16 Jul 2015 13:28:50 +0000 (18:58 +0530)
At device removal, tasklets are not disabled and irqs are still enabled, so
free the irq explicitly on device removal

Signed-off-by: Vinod Koul <vinod.koul@intel.com>
drivers/dma/zx296702_dma.c

index c99f0d1ac88a8326fe2eeb8deb9892c561af0af1..ec470bc74df8d6d8a7e5ce3c41a39565946d2444 100644 (file)
@@ -127,6 +127,7 @@ struct zx_dma_dev {
        struct dma_pool         *pool;
        u32                     dma_channels;
        u32                     dma_requests;
+       int                     irq;
 };
 
 #define to_zx_dma(dmadev) container_of(dmadev, struct zx_dma_dev, slave)
@@ -683,7 +684,7 @@ static int zx_dma_probe(struct platform_device *op)
 {
        struct zx_dma_dev *d;
        struct resource *iores;
-       int i, ret = 0, irq = 0;
+       int i, ret = 0;
 
        iores = platform_get_resource(op, IORESOURCE_MEM, 0);
        if (!iores)
@@ -710,8 +711,8 @@ static int zx_dma_probe(struct platform_device *op)
                return PTR_ERR(d->clk);
        }
 
-       irq = platform_get_irq(op, 0);
-       ret = devm_request_irq(&op->dev, irq, zx_dma_int_handler,
+       d->irq = platform_get_irq(op, 0);
+       ret = devm_request_irq(&op->dev, d->irq, zx_dma_int_handler,
                               0, DRIVER_NAME, d);
        if (ret)
                return ret;
@@ -807,6 +808,9 @@ static int zx_dma_remove(struct platform_device *op)
        struct zx_dma_chan *c, *cn;
        struct zx_dma_dev *d = platform_get_drvdata(op);
 
+       /* explictly free the irq */
+       devm_free_irq(&op->dev, d->irq, d);
+
        dma_async_device_unregister(&d->slave);
        of_dma_controller_free((&op->dev)->of_node);