diff options
author | Mark Brown <broonie@kernel.org> | 2019-05-12 12:08:03 +0900 |
---|---|---|
committer | Mark Brown <broonie@kernel.org> | 2019-05-12 12:08:03 +0900 |
commit | e727d4cbc785e9c1b4d239eef274dc63bc1aff24 (patch) | |
tree | a10ba6c1e779731d281f9f8916cfb0e7a730ea6b | |
parent | 47300728fb213486a830565d2af49da967c9d16a (diff) | |
parent | e6f3f7e4dc76eb8d8a546dc66621a02c5c84f4ac (diff) |
Merge tag 'spi-bpw-is-supported' of https://git.kernel.org/pub/scm/linux/kernel/git/broonie/spi into spi-5.3
spi: Add spi_is_bpw_supported()
Lets client drivers check and potentially handle issues.
-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 e552a036cb4d..f55b20254612 100644 --- a/include/linux/spi/spi.h +++ b/include/linux/spi/spi.h @@ -1005,6 +1005,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 */ |