Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

spi: spi-cadence: enable SPI_CONTROLLER_MUST_TX

During an SPI read operation, even if the xspi->txbuf passed to the
cdns_spi_writerinterface is empty, it is still necessary to call
cdns_spi_write(xspi, CDNS_SPI_TXD, txw); otherwise, the read operation
will fail to obtain data correctly due to a lack of clocks.

Fixes: 4e00135b2dd1 ("spi: spi-cadence: supports transmission with bits_per_word of 16 and 32")
Reported-by: Rodrigo Alencar <455.rodrigo.alencar@gmail.com>
Closes: https://lore.kernel.org/all/lbijvnnwsnddonmm5pveqzap6iibxhl4maneq43x4j6w64dev6@u75qhm5cwiob/
Signed-off-by: Jun Guo <jun.guo@cixtech.com>
Link: https://patch.msgid.link/20260115091924.844179-1-jun.guo@cixtech.com
Signed-off-by: Mark Brown <broonie@kernel.org>

authored by

Jun Guo and committed by
Mark Brown
f6b62563 b062a899

+1
+1
drivers/spi/spi-cadence.c
··· 729 729 ctlr->unprepare_transfer_hardware = cdns_unprepare_transfer_hardware; 730 730 ctlr->mode_bits = SPI_CPOL | SPI_CPHA; 731 731 ctlr->bits_per_word_mask = SPI_BPW_MASK(8); 732 + ctlr->flags = SPI_CONTROLLER_MUST_TX; 732 733 733 734 if (of_device_is_compatible(pdev->dev.of_node, "cix,sky1-spi-r1p6")) 734 735 ctlr->bits_per_word_mask |= SPI_BPW_MASK(16) | SPI_BPW_MASK(32);