提交 2a03c131 编写于 作者: C Chuhong Yuan 提交者: Vinod Koul

dmaengine: ti: edma: add missed operations

The driver forgets to call pm_runtime_disable and pm_runtime_put_sync in
probe failure and remove.
Add the calls and modify probe failure handling to fix it.

To simplify the fix, the patch adjusts the calling order and merges checks
for devm_kcalloc.

Fixes: 2b6b3b74 ("ARM/dmaengine: edma: Merge the two drivers under drivers/dma/")
Signed-off-by: NChuhong Yuan <hslester96@gmail.com>
Acked-by: NPeter Ujfalusi <peter.ujfalusi@ti.com>
Link: https://lore.kernel.org/r/20191124052855.6472-1-hslester96@gmail.comSigned-off-by: NVinod Koul <vkoul@kernel.org>
上级 e42617b8
...@@ -2289,13 +2289,6 @@ static int edma_probe(struct platform_device *pdev) ...@@ -2289,13 +2289,6 @@ static int edma_probe(struct platform_device *pdev)
if (!info) if (!info)
return -ENODEV; return -ENODEV;
pm_runtime_enable(dev);
ret = pm_runtime_get_sync(dev);
if (ret < 0) {
dev_err(dev, "pm_runtime_get_sync() failed\n");
return ret;
}
ret = dma_set_mask_and_coherent(dev, DMA_BIT_MASK(32)); ret = dma_set_mask_and_coherent(dev, DMA_BIT_MASK(32));
if (ret) if (ret)
return ret; return ret;
...@@ -2326,27 +2319,31 @@ static int edma_probe(struct platform_device *pdev) ...@@ -2326,27 +2319,31 @@ static int edma_probe(struct platform_device *pdev)
platform_set_drvdata(pdev, ecc); platform_set_drvdata(pdev, ecc);
pm_runtime_enable(dev);
ret = pm_runtime_get_sync(dev);
if (ret < 0) {
dev_err(dev, "pm_runtime_get_sync() failed\n");
pm_runtime_disable(dev);
return ret;
}
/* Get eDMA3 configuration from IP */ /* Get eDMA3 configuration from IP */
ret = edma_setup_from_hw(dev, info, ecc); ret = edma_setup_from_hw(dev, info, ecc);
if (ret) if (ret)
return ret; goto err_disable_pm;
/* Allocate memory based on the information we got from the IP */ /* Allocate memory based on the information we got from the IP */
ecc->slave_chans = devm_kcalloc(dev, ecc->num_channels, ecc->slave_chans = devm_kcalloc(dev, ecc->num_channels,
sizeof(*ecc->slave_chans), GFP_KERNEL); sizeof(*ecc->slave_chans), GFP_KERNEL);
if (!ecc->slave_chans)
return -ENOMEM;
ecc->slot_inuse = devm_kcalloc(dev, BITS_TO_LONGS(ecc->num_slots), ecc->slot_inuse = devm_kcalloc(dev, BITS_TO_LONGS(ecc->num_slots),
sizeof(unsigned long), GFP_KERNEL); sizeof(unsigned long), GFP_KERNEL);
if (!ecc->slot_inuse)
return -ENOMEM;
ecc->channels_mask = devm_kcalloc(dev, ecc->channels_mask = devm_kcalloc(dev,
BITS_TO_LONGS(ecc->num_channels), BITS_TO_LONGS(ecc->num_channels),
sizeof(unsigned long), GFP_KERNEL); sizeof(unsigned long), GFP_KERNEL);
if (!ecc->channels_mask) if (!ecc->slave_chans || !ecc->slot_inuse || !ecc->channels_mask)
return -ENOMEM; goto err_disable_pm;
/* Mark all channels available initially */ /* Mark all channels available initially */
bitmap_fill(ecc->channels_mask, ecc->num_channels); bitmap_fill(ecc->channels_mask, ecc->num_channels);
...@@ -2388,7 +2385,7 @@ static int edma_probe(struct platform_device *pdev) ...@@ -2388,7 +2385,7 @@ static int edma_probe(struct platform_device *pdev)
ecc); ecc);
if (ret) { if (ret) {
dev_err(dev, "CCINT (%d) failed --> %d\n", irq, ret); dev_err(dev, "CCINT (%d) failed --> %d\n", irq, ret);
return ret; goto err_disable_pm;
} }
ecc->ccint = irq; ecc->ccint = irq;
} }
...@@ -2404,7 +2401,7 @@ static int edma_probe(struct platform_device *pdev) ...@@ -2404,7 +2401,7 @@ static int edma_probe(struct platform_device *pdev)
ecc); ecc);
if (ret) { if (ret) {
dev_err(dev, "CCERRINT (%d) failed --> %d\n", irq, ret); dev_err(dev, "CCERRINT (%d) failed --> %d\n", irq, ret);
return ret; goto err_disable_pm;
} }
ecc->ccerrint = irq; ecc->ccerrint = irq;
} }
...@@ -2412,7 +2409,8 @@ static int edma_probe(struct platform_device *pdev) ...@@ -2412,7 +2409,8 @@ static int edma_probe(struct platform_device *pdev)
ecc->dummy_slot = edma_alloc_slot(ecc, EDMA_SLOT_ANY); ecc->dummy_slot = edma_alloc_slot(ecc, EDMA_SLOT_ANY);
if (ecc->dummy_slot < 0) { if (ecc->dummy_slot < 0) {
dev_err(dev, "Can't allocate PaRAM dummy slot\n"); dev_err(dev, "Can't allocate PaRAM dummy slot\n");
return ecc->dummy_slot; ret = ecc->dummy_slot;
goto err_disable_pm;
} }
queue_priority_mapping = info->queue_priority_mapping; queue_priority_mapping = info->queue_priority_mapping;
...@@ -2512,6 +2510,9 @@ static int edma_probe(struct platform_device *pdev) ...@@ -2512,6 +2510,9 @@ static int edma_probe(struct platform_device *pdev)
err_reg1: err_reg1:
edma_free_slot(ecc, ecc->dummy_slot); edma_free_slot(ecc, ecc->dummy_slot);
err_disable_pm:
pm_runtime_put_sync(dev);
pm_runtime_disable(dev);
return ret; return ret;
} }
...@@ -2542,6 +2543,8 @@ static int edma_remove(struct platform_device *pdev) ...@@ -2542,6 +2543,8 @@ static int edma_remove(struct platform_device *pdev)
if (ecc->dma_memcpy) if (ecc->dma_memcpy)
dma_async_device_unregister(ecc->dma_memcpy); dma_async_device_unregister(ecc->dma_memcpy);
edma_free_slot(ecc, ecc->dummy_slot); edma_free_slot(ecc, ecc->dummy_slot);
pm_runtime_put_sync(dev);
pm_runtime_disable(dev);
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册