spi/bfin_spi: check per-transfer bits_per_word
authorBob Liu <lliubbo@gmail.com>
Fri, 17 Sep 2010 03:46:22 +0000 (03:46 +0000)
committerMike Frysinger <vapier@gentoo.org>
Mon, 18 Oct 2010 06:49:43 +0000 (02:49 -0400)
Currently, if the bits_per_word when doing a transfer is not 8bits, we
always treat it as 16bits when we should actually be returning an error.

Signed-off-by: Bob Liu <lliubbo@gmail.com>
Signed-off-by: Mike Frysinger <vapier@gentoo.org>
drivers/spi/spi_bfin5xx.c

index 21de860..bd18214 100644 (file)
@@ -644,11 +644,16 @@ static void bfin_spi_pump_transfers(unsigned long data)
                drv_data->len = transfer->len;
                cr_width = 0;
                drv_data->ops = &bfin_transfer_ops_u8;
-       } else {
+       } else if (bits_per_word == 16) {
                drv_data->n_bytes = 2;
                drv_data->len = (transfer->len) >> 1;
                cr_width = BIT_CTL_WORDSIZE;
                drv_data->ops = &bfin_transfer_ops_u16;
+       } else {
+               dev_err(&drv_data->pdev->dev, "transfer: unsupported bits_per_word\n");
+               message->status = -EINVAL;
+               bfin_spi_giveback(drv_data);
+               return;
        }
        cr = read_CTRL(drv_data) & ~(BIT_CTL_TIMOD | BIT_CTL_WORDSIZE);
        cr |= cr_width;