From e317af0a84fd0430a14e818626e66cf46825d79a Mon Sep 17 00:00:00 2001 From: SPRESENSE <41312067+SPRESENSE@users.noreply.github.com> Date: Wed, 25 Jan 2023 18:14:06 +0900 Subject: [PATCH] arch: cxd56xx: Fix SPI transfer without DMA SPI transfers are dynamically determined to use DMA or not. The flag to judge is removed in a previous simple refactoring commit. Revert the logic and fix an issue that SPI transfer fails. --- arch/arm/src/cxd56xx/cxd56_spi.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/arch/arm/src/cxd56xx/cxd56_spi.c b/arch/arm/src/cxd56xx/cxd56_spi.c index bc33926de3..eae4cc3b26 100644 --- a/arch/arm/src/cxd56xx/cxd56_spi.c +++ b/arch/arm/src/cxd56xx/cxd56_spi.c @@ -77,6 +77,7 @@ struct cxd56_spidev_s uint8_t port; /* Port number */ int initialized; /* Initialized flag */ #ifdef CONFIG_CXD56_DMAC + bool dmaenable; /* Use DMA or not */ DMA_HANDLE rxdmach; /* RX DMA channel handle */ DMA_HANDLE txdmach; /* TX DMA channel handle */ sem_t dmasem; /* Wait for DMA to complete */ @@ -878,13 +879,15 @@ static void spi_exchange(struct spi_dev_s *dev, const void *txbuffer, void *rxbuffer, size_t nwords) { #ifdef CONFIG_CXD56_DMAC + struct cxd56_spidev_s *priv = (struct cxd56_spidev_s *)dev; + #ifdef CONFIG_CXD56_SPI_DMATHRESHOLD size_t dmath = CONFIG_CXD56_SPI_DMATHRESHOLD; #else size_t dmath = 0; #endif - if (dmath < nwords) + if (priv->dmaenable && dmath < nwords) { spi_dmaexchange(dev, txbuffer, rxbuffer, nwords); } @@ -1217,6 +1220,7 @@ struct spi_dev_s *cxd56_spibus_initialize(int port) /* DMA settings */ #ifdef CONFIG_CXD56_DMAC + priv->dmaenable = false; priv->txdmach = NULL; priv->rxdmach = NULL; #endif @@ -1334,6 +1338,7 @@ void cxd56_spi_dmaconfig(int port, int chtype, DMA_HANDLE handle, { /* TX DMA setting */ + priv->dmaenable = true; priv->txdmach = handle; memcpy(&priv->txconfig, conf, sizeof(dma_config_t)); } @@ -1341,6 +1346,7 @@ void cxd56_spi_dmaconfig(int port, int chtype, DMA_HANDLE handle, { /* RX DMA setting */ + priv->dmaenable = true; priv->rxdmach = handle; memcpy(&priv->rxconfig, conf, sizeof(dma_config_t)); }