Skip to content

Commit 92dc20d

Browse files
avostrikbroonie
authored andcommitted
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>
1 parent f55532a commit 92dc20d

File tree

1 file changed

+2
-2
lines changed

1 file changed

+2
-2
lines changed

drivers/spi/spi-fsl-dspi.c

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -385,8 +385,8 @@ static int dspi_transfer_one_message(struct spi_master *master,
385385
dspi->cur_chip = spi_get_ctldata(spi);
386386
dspi->cs = spi->chip_select;
387387
dspi->cs_change = 0;
388-
if (dspi->cur_transfer->transfer_list.next
389-
== &dspi->cur_msg->transfers)
388+
if (list_is_last(&dspi->cur_transfer->transfer_list,
389+
&dspi->cur_msg->transfers) || transfer->cs_change)
390390
dspi->cs_change = 1;
391391
dspi->void_write_data = dspi->cur_chip->void_write_data;
392392

0 commit comments

Comments
 (0)