mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-25 21:59:32 +00:00
a2a75c21bd
Compile and runtime tested on lantiq/xrx200 and x86/64. Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
33 lines
1.1 KiB
Diff
33 lines
1.1 KiB
Diff
From 02554ec274e6b76eb827f384c38f9c67fe93cb8a Mon Sep 17 00:00:00 2001
|
|
From: Phil Elwell <phil@raspberrypi.org>
|
|
Date: Tue, 3 Jul 2018 14:23:47 +0100
|
|
Subject: [PATCH 358/454] spi: Make GPIO CSs honour the SPI_NO_CS flag
|
|
|
|
The SPI configuration state includes an SPI_NO_CS flag that disables
|
|
all CS line manipulation, for applications that want to manage their
|
|
own chip selects. However, this flag is ignored by the GPIO CS code
|
|
in the SPI framework.
|
|
|
|
Correct this omission with a trivial patch.
|
|
|
|
See: https://github.com/raspberrypi/linux/issues/2169
|
|
|
|
Signed-off-by: Phil Elwell <phil@raspberrypi.org>
|
|
---
|
|
drivers/spi/spi.c | 4 +++-
|
|
1 file changed, 3 insertions(+), 1 deletion(-)
|
|
|
|
--- a/drivers/spi/spi.c
|
|
+++ b/drivers/spi/spi.c
|
|
@@ -741,7 +741,9 @@ static void spi_set_cs(struct spi_device
|
|
enable = !enable;
|
|
|
|
if (gpio_is_valid(spi->cs_gpio)) {
|
|
- gpio_set_value_cansleep(spi->cs_gpio, !enable);
|
|
+ /* Honour the SPI_NO_CS flag */
|
|
+ if (!(spi->mode & SPI_NO_CS))
|
|
+ gpio_set_value(spi->cs_gpio, !enable);
|
|
/* Some SPI masters need both GPIO CS & slave_select */
|
|
if ((spi->controller->flags & SPI_MASTER_GPIO_SS) &&
|
|
spi->controller->set_cs)
|