Commit cabb5b2a authored by Stefan Wahren's avatar Stefan Wahren Committed by Greg Kroah-Hartman

staging: fbtft: fix 9-bit SPI support detection

Since the result of the setup function isn't adequate to check
9-bit SPI support, we better check bits_per_word_mask. Btw this
change avoids a NULL pointer dereference with master drivers
without a separate setup function.
Signed-off-by: default avatarStefan Wahren <stefan.wahren@i2se.com>
Acked-by: default avatarNoralf Trønnes <noralf@tronnes.org>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent d98229f0
...@@ -1436,15 +1436,11 @@ int fbtft_probe_common(struct fbtft_display *display, ...@@ -1436,15 +1436,11 @@ int fbtft_probe_common(struct fbtft_display *display,
/* 9-bit SPI setup */ /* 9-bit SPI setup */
if (par->spi && display->buswidth == 9) { if (par->spi && display->buswidth == 9) {
if (par->spi->master->bits_per_word_mask & SPI_BPW_MASK(9)) {
par->spi->bits_per_word = 9; par->spi->bits_per_word = 9;
ret = par->spi->master->setup(par->spi); } else {
if (ret) {
dev_warn(&par->spi->dev, dev_warn(&par->spi->dev,
"9-bit SPI not available, emulating using 8-bit.\n"); "9-bit SPI not available, emulating using 8-bit.\n");
par->spi->bits_per_word = 8;
ret = par->spi->master->setup(par->spi);
if (ret)
goto out_release;
/* allocate buffer with room for dc bits */ /* allocate buffer with room for dc bits */
par->extra = devm_kzalloc(par->info->device, par->extra = devm_kzalloc(par->info->device,
par->txbuf.len + (par->txbuf.len / 8) + 8, par->txbuf.len + (par->txbuf.len / 8) + 8,
......
...@@ -463,15 +463,12 @@ static int flexfb_probe_common(struct spi_device *sdev, ...@@ -463,15 +463,12 @@ static int flexfb_probe_common(struct spi_device *sdev,
} }
par->fbtftops.write_register = fbtft_write_reg8_bus9; par->fbtftops.write_register = fbtft_write_reg8_bus9;
par->fbtftops.write_vmem = fbtft_write_vmem16_bus9; par->fbtftops.write_vmem = fbtft_write_vmem16_bus9;
sdev->bits_per_word = 9; if (par->spi->master->bits_per_word_mask
ret = sdev->master->setup(sdev); & SPI_BPW_MASK(9)) {
if (ret) { par->spi->bits_per_word = 9;
} else {
dev_warn(dev, dev_warn(dev,
"9-bit SPI not available, emulating using 8-bit.\n"); "9-bit SPI not available, emulating using 8-bit.\n");
sdev->bits_per_word = 8;
ret = sdev->master->setup(sdev);
if (ret)
goto out_release;
/* allocate buffer with room for dc bits */ /* allocate buffer with room for dc bits */
par->extra = devm_kzalloc(par->info->device, par->extra = devm_kzalloc(par->info->device,
par->txbuf.len + (par->txbuf.len / 8) + 8, par->txbuf.len + (par->txbuf.len / 8) + 8,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment