diff options
author | Noralf Trønnes <noralf@tronnes.org> | 2019-04-12 11:41:30 +0200 |
---|---|---|
committer | Mark Brown <broonie@kernel.org> | 2019-04-12 11:13:36 +0100 |
commit | e6f3f7e4dc76eb8d8a546dc66621a02c5c84f4ac (patch) | |
tree | b8ff75206fc95d2cdbdd66097ced05a7fa66e9bd /include/linux/spi/spi.h | |
parent | 9e98c678c2d6ae3a17cb2de55d17f69dddaa231b (diff) | |
download | linux-e6f3f7e4dc76eb8d8a546dc66621a02c5c84f4ac.tar.gz linux-e6f3f7e4dc76eb8d8a546dc66621a02c5c84f4ac.tar.bz2 linux-e6f3f7e4dc76eb8d8a546dc66621a02c5c84f4ac.zip |
spi: Add spi_is_bpw_supported()
This let SPI clients check if the controller supports a particular word
width. drivers/gpu/drm/tinydrm/mipi-dbi.c will use this to determine if
the controller supports 16-bit for RGB565 pixels. If it doesn't it will
swap the bytes before transfer on little endian machines.
Signed-off-by: Noralf Trønnes <noralf@tronnes.org>
Signed-off-by: Mark Brown <broonie@kernel.org>
Diffstat (limited to 'include/linux/spi/spi.h')
-rw-r--r-- | include/linux/spi/spi.h | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/include/linux/spi/spi.h b/include/linux/spi/spi.h index 662b336aa2e4..b30e3d13a5ac 100644 --- a/include/linux/spi/spi.h +++ b/include/linux/spi/spi.h @@ -983,6 +983,26 @@ spi_max_transfer_size(struct spi_device *spi) return min(tr_max, msg_max); } +/** + * spi_is_bpw_supported - Check if bits per word is supported + * @spi: SPI device + * @bpw: Bits per word + * + * This function checks to see if the SPI controller supports @bpw. + * + * Returns: + * True if @bpw is supported, false otherwise. + */ +static inline bool spi_is_bpw_supported(struct spi_device *spi, u32 bpw) +{ + u32 bpw_mask = spi->master->bits_per_word_mask; + + if (bpw == 8 || (bpw <= 32 && bpw_mask & SPI_BPW_MASK(bpw))) + return true; + + return false; +} + /*---------------------------------------------------------------------------*/ /* SPI transfer replacement methods which make use of spi_res */ |