spi: rockchip: fix missing error on unsupported SPI_CS_HIGH
authorLuca Ceresoli <luca.ceresoli@bootlin.com>
Thu, 21 Apr 2022 21:32:51 +0000 (23:32 +0200)
committerMark Brown <broonie@kernel.org>
Mon, 25 Apr 2022 13:01:01 +0000 (14:01 +0100)
commitd5d933f09ac326aebad85bfb787cc786ad477711
tree5540847d65f8467d2a8d741dea18b4bcecba33bb
parent40b6a137717bb5ca5ccb4e4b051e0d22019cd188
spi: rockchip: fix missing error on unsupported SPI_CS_HIGH

The hardware (except for the ROCKCHIP_SPI_VER2_TYPE2 version) does not
support active-high native chip selects. However if such a CS is configured
the core does not error as it normally should, because the
'ctlr->use_gpio_descriptors = true' line in rockchip_spi_probe() makes the
core set SPI_CS_HIGH in ctlr->mode_bits.

In such a case the spi-rockchip driver operates normally but produces an
active-low chip select signal without notice.

There is no provision in the current core code to handle this
situation. Fix by adding a check in the ctlr->setup function (similarly to
what spi-atmel.c does).

This cannot be done reading the SPI_CS_HIGH but in ctlr->mode_bits because
that bit gets always set by the core for master mode (see above).

Fixes: eb1262e3cc8b ("spi: spi-rockchip: use num-cs property and ctlr->enable_gpiods")
Signed-off-by: Luca Ceresoli <luca.ceresoli@bootlin.com>
Link: https://lore.kernel.org/r/20220421213251.1077899-1-luca.ceresoli@bootlin.com
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-rockchip.c