• Luca Ceresoli's avatar
    spi: rockchip: fix missing error on unsupported SPI_CS_HIGH · d5d933f0
    Luca Ceresoli authored
    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: eb1262e3 ("spi: spi-rockchip: use num-cs property and ctlr->enable_gpiods")
    Signed-off-by: default avatarLuca Ceresoli <luca.ceresoli@bootlin.com>
    Link: https://lore.kernel.org/r/20220421213251.1077899-1-luca.ceresoli@bootlin.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
    d5d933f0
spi-rockchip.c 27.5 KB