aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFranklin S Cooper Jr <fcooper@ti.com>2015-10-16 11:29:03 -0400
committerMark Brown <broonie@kernel.org>2015-10-27 20:34:18 -0400
commitabeedb0159eec42c52a28fc44457164f71aa12a9 (patch)
tree0b66cf806bda18184acc6c99d6c1c5c7373d173d
parent6ff33f3902c3b1c5d0db6b1e2c70b6d76fba357f (diff)
spi: Setup the master controller driver before setting the chipselect
SPI controllers may need to be properly setup before chip selects can be used. Therefore, wait until the spi controller has a chance to perform their setup procedure before trying to use the chip select. This also insures that the chip selects pins are in a good state before asseting them which otherwise may cause confusion. Signed-off-by: Franklin S Cooper Jr <fcooper@ti.com> Tested-by: Grygorii Strashko <grygorii.strashko@ti.com> Tested-by: Ivan Khoronzhuk <ivan.khoronzhuk@linaro.org> Signed-off-by: Mark Brown <broonie@kernel.org>
-rw-r--r--drivers/spi/spi.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/spi/spi.c b/drivers/spi/spi.c
index 3abb3903f2ad..7b528b0aedb9 100644
--- a/drivers/spi/spi.c
+++ b/drivers/spi/spi.c
@@ -1993,11 +1993,11 @@ int spi_setup(struct spi_device *spi)
1993 if (!spi->max_speed_hz) 1993 if (!spi->max_speed_hz)
1994 spi->max_speed_hz = spi->master->max_speed_hz; 1994 spi->max_speed_hz = spi->master->max_speed_hz;
1995 1995
1996 spi_set_cs(spi, false);
1997
1998 if (spi->master->setup) 1996 if (spi->master->setup)
1999 status = spi->master->setup(spi); 1997 status = spi->master->setup(spi);
2000 1998
1999 spi_set_cs(spi, false);
2000
2001 dev_dbg(&spi->dev, "setup mode %d, %s%s%s%s%u bits/w, %u Hz max --> %d\n", 2001 dev_dbg(&spi->dev, "setup mode %d, %s%s%s%s%u bits/w, %u Hz max --> %d\n",
2002 (int) (spi->mode & (SPI_CPOL | SPI_CPHA)), 2002 (int) (spi->mode & (SPI_CPOL | SPI_CPHA)),
2003 (spi->mode & SPI_CS_HIGH) ? "cs_high, " : "", 2003 (spi->mode & SPI_CS_HIGH) ? "cs_high, " : "",