From db945bdd8659e7aa37e1687f4e70f6fbc18d99ba Mon Sep 17 00:00:00 2001 From: Gunar Schorcht Date: Tue, 22 Oct 2019 08:11:25 +0200 Subject: [PATCH] cpu/esp32: fix CS handling in spi_transfer_bytes If `SPI_CS_UNDEF` is given as the `cs` parameter, CS pin must not be handled by the driver. Furthermore, if `cont` parameter is true, CS pin must not be disabled at the end of one transfer. --- cpu/esp32/periph/spi.c | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/cpu/esp32/periph/spi.c b/cpu/esp32/periph/spi.c index 284afb7ebd..2af333f6d1 100644 --- a/cpu/esp32/periph/spi.c +++ b/cpu/esp32/periph/spi.c @@ -456,7 +456,9 @@ void IRAM_ATTR spi_transfer_bytes(spi_t bus, spi_cs_t cs, bool cont, } #endif - gpio_clear (cs != SPI_CS_UNDEF ? cs : spi_config[bus].cs); + if (cs != SPI_CS_UNDEF) { + gpio_clear(cs); + } size_t blocks = len / SPI_BLOCK_SIZE; uint8_t tail = len % SPI_BLOCK_SIZE; @@ -474,8 +476,9 @@ void IRAM_ATTR spi_transfer_bytes(spi_t bus, spi_cs_t cs, bool cont, out ? (const uint8_t *)out + blocks * SPI_BLOCK_SIZE : 0, in ? (uint8_t *)in + blocks * SPI_BLOCK_SIZE : NULL, tail); } - if (!cont) { - gpio_set (cs != SPI_CS_UNDEF ? cs : spi_config[bus].cs); + + if (!cont && (cs != SPI_CS_UNDEF)) { + gpio_set (cs); } #if ENABLE_DEBUG