dmaengine: fsl-edma: fix edma4 channel enable failure on second attempt
authorFrank Li <Frank.Li@nxp.com>
Wed, 23 Aug 2023 18:26:35 +0000 (14:26 -0400)
committerVinod Koul <vkoul@kernel.org>
Thu, 28 Sep 2023 11:28:57 +0000 (16:58 +0530)
commit3f4b82167a3b1f4ddb33d890f758a042ef4ceef1
tree6cda9d13183e79dd4d12539d895365c079d8b7ef
parent54a5aff6f98b69e73cba40470f103a72bd436b20
dmaengine: fsl-edma: fix edma4 channel enable failure on second attempt

When attempting to start DMA for the second time using
fsl_edma3_enable_request(), channel never start.

CHn_MUX must have a unique value when selecting a peripheral slot in the
channel mux configuration. The only value that may overlap is source 0.
If there is an attempt to write a mux configuration value that is already
consumed by another channel, a mux configuration of 0 (SRC = 0) will be
written.

Check CHn_MUX before writing in fsl_edma3_enable_request().

Fixes: 72f5801a4e2b ("dmaengine: fsl-edma: integrate v3 support")
Signed-off-by: Frank Li <Frank.Li@nxp.com>
Link: https://lore.kernel.org/r/20230823182635.2618118-1-Frank.Li@nxp.com
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/dma/fsl-edma-common.c