diff options
author | Peter Ujfalusi <peter.ujfalusi@ti.com> | 2019-08-23 08:56:14 -0400 |
---|---|---|
committer | Vinod Koul <vkoul@kernel.org> | 2019-09-04 05:49:19 -0400 |
commit | c5dbe60664b3660f5ac5854e21273ea2e7ff698f (patch) | |
tree | c3acc8432482823f9c5259ba2cd74d1da6ac48b5 | |
parent | d17d9ea9572796f13f4aa2fed6cfb9e7fdf44406 (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.c | 9 |
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) { |