spi: Add generic support for unused native cs with cs-gpios
authorGeert Uytterhoeven <geert+renesas@glider.be>
Thu, 2 Jan 2020 13:38:17 +0000 (14:38 +0100)
committerMark Brown <broonie@kernel.org>
Tue, 7 Jan 2020 22:32:25 +0000 (22:32 +0000)
commit7d93aecdb58d47e8ed90b4a44c0fc9ffb8de941c
treea3a1a80bec2e56e8a38013485aba88727cda38bf
parente9aa3b851428282d5e5151a49d4bf0bfdcd72bfe
spi: Add generic support for unused native cs with cs-gpios

Some SPI master controllers always drive a native chip select when
performing a transfer.  Hence when using both native and GPIO chip
selects, at least one native chip select must be left unused, to be
driven when performing transfers with slave devices using GPIO chip
selects.

Currently, to find an unused native chip select, SPI controller drivers
need to parse and process cs-gpios theirselves.  This is not only
duplicated in each driver that needs it, but also duplicates part of the
work done later at SPI controller registration time.  Note that this
cannot be done after spi_register_controller() returns, as at that time,
slave devices may have been probed already.

Hence add generic support to the SPI subsystem for finding an unused
native chip select.  Optionally, this unused native chip select, and all
other in-use native chip selects, can be validated against the maximum
number of native chip selects available on the controller hardware.

Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
Link: https://lore.kernel.org/r/20200102133822.29346-2-geert+renesas@glider.be
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi.c
include/linux/spi/spi.h