diff mbox

spi: spi-ath79: fix initial GPIO CS line setup

Message ID 1393790082-23964-1-git-send-email-juhosg@openwrt.org (mailing list archive)
State Accepted
Commit 61d1cf163c8653934cc8cd5d0b2a562d0990c265
Headers show

Commit Message

Gabor Juhos March 2, 2014, 7:54 p.m. UTC
The 'ath79_spi_setup_cs' function initializes the chip
select line of a given SPI device in order to make sure
that the device is inactive.

If the SPI_CS_HIGH bit is set for a given device, it
means that the CS line of that device is active HIGH
so it must be set to LOW initially. In case of GPIO
CS lines, the 'ath79_spi_setup_cs' function does the
opposite of that due to the wrong GPIO flags.

Fix the code to use the correct GPIO flags.

Reported-by: Ronald Wahl <ronald.wahl@raritan.com>
Signed-off-by: Gabor Juhos <juhosg@openwrt.org>
---
 drivers/spi/spi-ath79.c |    4 ++--
 1 file changed, 2 insertions(+), 2 deletions(-)

Comments

Mark Brown March 3, 2014, 4:39 a.m. UTC | #1
On Sun, Mar 02, 2014 at 08:54:42PM +0100, Gabor Juhos wrote:
> The 'ath79_spi_setup_cs' function initializes the chip
> select line of a given SPI device in order to make sure
> that the device is inactive.

Applied, thanks.
diff mbox

Patch

diff --git a/drivers/spi/spi-ath79.c b/drivers/spi/spi-ath79.c
index 31534b5..c3b2fb9 100644
--- a/drivers/spi/spi-ath79.c
+++ b/drivers/spi/spi-ath79.c
@@ -132,9 +132,9 @@  static int ath79_spi_setup_cs(struct spi_device *spi)
 
 		flags = GPIOF_DIR_OUT;
 		if (spi->mode & SPI_CS_HIGH)
-			flags |= GPIOF_INIT_HIGH;
-		else
 			flags |= GPIOF_INIT_LOW;
+		else
+			flags |= GPIOF_INIT_HIGH;
 
 		status = gpio_request_one(cdata->gpio, flags,
 					  dev_name(&spi->dev));