summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPeter Ujfalusi <peter.ujfalusi@ti.com>2019-08-23 08:56:14 -0400
committerVinod Koul <vkoul@kernel.org>2019-09-04 05:49:19 -0400
commitc5dbe60664b3660f5ac5854e21273ea2e7ff698f (patch)
treec3acc8432482823f9c5259ba2cd74d1da6ac48b5
parentd17d9ea9572796f13f4aa2fed6cfb9e7fdf44406 (diff)
dmaengine: ti: edma: Do not reset reserved paRAM slots
Skip resetting paRAM slots marked as reserved as they might be used by other cores. Signed-off-by: Peter Ujfalusi <peter.ujfalusi@ti.com> Link: https://lore.kernel.org/r/20190823125618.8133-2-peter.ujfalusi@ti.com Signed-off-by: Vinod Koul <vkoul@kernel.org>
-rw-r--r--drivers/dma/ti/edma.c9
1 files changed, 6 insertions, 3 deletions
diff --git a/drivers/dma/ti/edma.c b/drivers/dma/ti/edma.c
index 54895112ba59..1aae95cc0d4b 100644
--- a/drivers/dma/ti/edma.c
+++ b/drivers/dma/ti/edma.c
@@ -2338,9 +2338,6 @@ static int edma_probe(struct platform_device *pdev)
2338 2338
2339 ecc->default_queue = info->default_queue; 2339 ecc->default_queue = info->default_queue;
2340 2340
2341 for (i = 0; i < ecc->num_slots; i++)
2342 edma_write_slot(ecc, i, &dummy_paramset);
2343
2344 if (info->rsv) { 2341 if (info->rsv) {
2345 /* Set the reserved slots in inuse list */ 2342 /* Set the reserved slots in inuse list */
2346 rsv_slots = info->rsv->rsv_slots; 2343 rsv_slots = info->rsv->rsv_slots;
@@ -2353,6 +2350,12 @@ static int edma_probe(struct platform_device *pdev)
2353 } 2350 }
2354 } 2351 }
2355 2352
2353 for (i = 0; i < ecc->num_slots; i++) {
2354 /* Reset only unused - not reserved - paRAM slots */
2355 if (!test_bit(i, ecc->slot_inuse))
2356 edma_write_slot(ecc, i, &dummy_paramset);
2357 }
2358
2356 /* Clear the xbar mapped channels in unused list */ 2359 /* Clear the xbar mapped channels in unused list */
2357 xbar_chans = info->xbar_chans; 2360 xbar_chans = info->xbar_chans;
2358 if (xbar_chans) { 2361 if (xbar_chans) {