From de3737cd90c72f7db7dd84906da99ef711115852 Mon Sep 17 00:00:00 2001 From: nuttxs Date: Wed, 17 Jul 2024 15:04:24 +0800 Subject: [PATCH] arch/xtensa/esp32s3: Deinitialize ESP32-S3 QSPI GDMA engine. Correctly releasing channels after using QSPI is crucial to prevent issues caused by multiple requests that may lead to DMA channel resource conflicts. --- arch/xtensa/src/esp32s3/esp32s3_qspi.c | 33 ++++++++++++++++++++++++-- 1 file changed, 31 insertions(+), 2 deletions(-) diff --git a/arch/xtensa/src/esp32s3/esp32s3_qspi.c b/arch/xtensa/src/esp32s3/esp32s3_qspi.c index 15b1df582f..d3fd20326d 100644 --- a/arch/xtensa/src/esp32s3/esp32s3_qspi.c +++ b/arch/xtensa/src/esp32s3/esp32s3_qspi.c @@ -1207,6 +1207,36 @@ void esp32s3_qspi_init_dma(struct esp32s3_qspi_priv_s *priv) putreg32((SPI_SLV_RX_SEG_TRANS_CLR_EN_M | SPI_SLV_TX_SEG_TRANS_CLR_EN_M), SPI_DMA_CONF_REG(config->id)); } + +/**************************************************************************** + * Name: esp32s3_qspi_dma_deinit + * + * Description: + * Deinitialize ESP32-S3 QSPI GDMA engine. + * + * Input Parameters: + * dev - Device-specific state data + * + * Returned Value: + * None. + * + ****************************************************************************/ + +void esp32s3_qspi_dma_deinit(struct esp32s3_qspi_priv_s *priv) +{ + /* Release a DMA channel from peripheral */ + + esp32s3_dma_release(priv->dma_channel); + + /* Deinitialize DMA controller */ + + esp32s3_dma_deinit(); + + /* Disable DMA clock for the SPI peripheral */ + + modifyreg32(SYSTEM_PERIP_CLK_EN0_REG, priv->config->dma_clk_bit, 0); +} + #endif /**************************************************************************** @@ -1391,8 +1421,7 @@ static void esp32s3_qspi_deinit(struct esp32s3_qspi_priv_s *priv) const struct esp32s3_qspi_config_s *config = priv->config; #ifdef CONFIG_ESP32S3_SPI_DMA - modifyreg32(SYSTEM_PERIP_RST_EN0_REG, 0, config->dma_rst_bit); - modifyreg32(SYSTEM_PERIP_CLK_EN0_REG, config->dma_clk_bit, 0); + esp32s3_qspi_dma_deinit(priv); #endif modifyreg32(SYSTEM_PERIP_RST_EN0_REG, 0, config->rst_bit);