mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2024-12-29 04:50:03 +01:00
Merge pull request #16926 from benpicco/cpu/sam0_common-dma_treshold
cpu/sam0_common: SPI: don't perform DMA transfer for small buffers
This commit is contained in:
commit
6439d7d5de
14
cpu/sam0_common/periph/Kconfig.spi
Normal file
14
cpu/sam0_common/periph/Kconfig.spi
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
# Copyright (c) 2020 HAW Hamburg
|
||||||
|
#
|
||||||
|
# This file is subject to the terms and conditions of the GNU Lesser
|
||||||
|
# General Public License v2.1. See the file LICENSE in the top level
|
||||||
|
# directory for more details.
|
||||||
|
|
||||||
|
config SPI_DMA_THRESHOLD_BYTES
|
||||||
|
int "SPI DMA threshold (bytes)"
|
||||||
|
depends on MODULE_PERIPH_DMA
|
||||||
|
depends on MODULE_PERIPH_SPI
|
||||||
|
default 16
|
||||||
|
help
|
||||||
|
Threshold in bytes under which no SPI DMA transfer will be performed.
|
||||||
|
Polling will be used instead.
|
@ -36,6 +36,14 @@
|
|||||||
#define ENABLE_DEBUG 0
|
#define ENABLE_DEBUG 0
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Threshold under which polling transfers are used instead of DMA
|
||||||
|
* TODO: determine at run-time based on SPI clock
|
||||||
|
*/
|
||||||
|
#ifndef CONFIG_SPI_DMA_THRESHOLD_BYTES
|
||||||
|
#define CONFIG_SPI_DMA_THRESHOLD_BYTES 16
|
||||||
|
#endif
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Array holding one pre-initialized mutex for each SPI device
|
* @brief Array holding one pre-initialized mutex for each SPI device
|
||||||
*/
|
*/
|
||||||
@ -508,7 +516,7 @@ void spi_transfer_bytes(spi_t bus, spi_cs_t cs, bool cont,
|
|||||||
gpio_clear((gpio_t)cs);
|
gpio_clear((gpio_t)cs);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_use_dma(bus)) {
|
if (_use_dma(bus) && len > CONFIG_SPI_DMA_THRESHOLD_BYTES) {
|
||||||
#ifdef MODULE_PERIPH_DMA
|
#ifdef MODULE_PERIPH_DMA
|
||||||
/* The DMA promises not to modify the const out data */
|
/* The DMA promises not to modify the const out data */
|
||||||
_dma_transfer(bus, out, in, len);
|
_dma_transfer(bus, out, in, len);
|
||||||
|
1
cpu/samd21/periph/Kconfig.spi
Normal file
1
cpu/samd21/periph/Kconfig.spi
Normal file
@ -0,0 +1 @@
|
|||||||
|
source "$(RIOTCPU)/sam0_common/periph/Kconfig.spi"
|
1
cpu/samd5x/periph/Kconfig.spi
Normal file
1
cpu/samd5x/periph/Kconfig.spi
Normal file
@ -0,0 +1 @@
|
|||||||
|
source "$(RIOTCPU)/sam0_common/periph/Kconfig.spi"
|
1
cpu/saml1x/periph/Kconfig.spi
Normal file
1
cpu/saml1x/periph/Kconfig.spi
Normal file
@ -0,0 +1 @@
|
|||||||
|
source "$(RIOTCPU)/sam0_common/periph/Kconfig.spi"
|
1
cpu/saml21/periph/Kconfig.spi
Normal file
1
cpu/saml21/periph/Kconfig.spi
Normal file
@ -0,0 +1 @@
|
|||||||
|
source "$(RIOTCPU)/sam0_common/periph/Kconfig.spi"
|
@ -41,4 +41,7 @@ config MODULE_PERIPH_INIT_SPI_GPIO_MODE
|
|||||||
default y if MODULE_PERIPH_INIT
|
default y if MODULE_PERIPH_INIT
|
||||||
depends on MODULE_PERIPH_SPI_GPIO_MODE
|
depends on MODULE_PERIPH_SPI_GPIO_MODE
|
||||||
|
|
||||||
|
# Include CPU specific configurations
|
||||||
|
osource "$(RIOTCPU)/$(CPU)/periph/Kconfig.spi"
|
||||||
|
|
||||||
endif # MODULE_PERIPH_SPI
|
endif # MODULE_PERIPH_SPI
|
||||||
|
Loading…
Reference in New Issue
Block a user