summaryrefslogtreecommitdiffstats
path: root/drivers/spi/spi-fsl-dspi.c
diff options
context:
space:
mode:
authorAndrey Vostrikov <andrey.vostrikov@cogentembedded.com>2016-04-05 08:33:14 -0400
committerMark Brown <broonie@kernel.org>2016-04-05 15:12:42 -0400
commit92dc20d83adec565378254c0630e839ff5674e14 (patch)
tree0f3a1330a6be9004757dd4f00f1808d2244766a7 /drivers/spi/spi-fsl-dspi.c
parentf55532a0c0b8bb6148f4e07853b876ef73bc69ca (diff)
spi: spi-fsl-dspi: Fix cs_change handling in message transfer
There are use cases when chip select should be triggered between transfers in single SPI message. Current implementation does this only on last transfer in message ignoring cs_change value provided in current transfer. Signed-off-by: Andrey Vostrikov <andrey.vostrikov@cogentembedded.com> Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'drivers/spi/spi-fsl-dspi.c')
-rw-r--r--drivers/spi/spi-fsl-dspi.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/drivers/spi/spi-fsl-dspi.c b/drivers/spi/spi-fsl-dspi.c
index 39412c9097c6..c1a2d747b246 100644
--- a/drivers/spi/spi-fsl-dspi.c
+++ b/drivers/spi/spi-fsl-dspi.c
@@ -385,8 +385,8 @@ static int dspi_transfer_one_message(struct spi_master *master,
385 dspi->cur_chip = spi_get_ctldata(spi); 385 dspi->cur_chip = spi_get_ctldata(spi);
386 dspi->cs = spi->chip_select; 386 dspi->cs = spi->chip_select;
387 dspi->cs_change = 0; 387 dspi->cs_change = 0;
388 if (dspi->cur_transfer->transfer_list.next 388 if (list_is_last(&dspi->cur_transfer->transfer_list,
389 == &dspi->cur_msg->transfers) 389 &dspi->cur_msg->transfers) || transfer->cs_change)
390 dspi->cs_change = 1; 390 dspi->cs_change = 1;
391 dspi->void_write_data = dspi->cur_chip->void_write_data; 391 dspi->void_write_data = dspi->cur_chip->void_write_data;
392 392