dmaengine: stm32-mdma: correct desc prep when channel running
authorAlain Volmat <alain.volmat@foss.st.com>
Mon, 9 Oct 2023 08:24:50 +0000 (10:24 +0200)
committerVinod Koul <vkoul@kernel.org>
Mon, 16 Oct 2023 11:10:38 +0000 (16:40 +0530)
commit03f25d53b145bc2f7ccc82fc04e4482ed734f524
tree34da345dfd2e0a704bd69810033ec03370924755
parent495e18b16e3dd8218eaec6a8a55334fb55245d59
dmaengine: stm32-mdma: correct desc prep when channel running

In case of the prep descriptor while the channel is already running, the
CCR register value stored into the channel could already have its EN bit
set.  This would lead to a bad transfer since, at start transfer time,
enabling the channel while other registers aren't yet properly set.
To avoid this, ensure to mask the CCR_EN bit when storing the ccr value
into the mdma channel structure.

Fixes: a4ffb13c8946 ("dmaengine: Add STM32 MDMA driver")
Signed-off-by: Alain Volmat <alain.volmat@foss.st.com>
Signed-off-by: Amelie Delaunay <amelie.delaunay@foss.st.com>
Cc: stable@vger.kernel.org
Tested-by: Alain Volmat <alain.volmat@foss.st.com>
Link: https://lore.kernel.org/r/20231009082450.452877-1-amelie.delaunay@foss.st.com
Signed-off-by: Vinod Koul <vkoul@kernel.org>
drivers/dma/stm32-mdma.c