spi: spi-mem-nodm: Fix read data size issue
authorBin Meng <bmeng.cn@gmail.com>
Wed, 28 Jul 2021 12:50:14 +0000 (20:50 +0800)
committerJagan Teki <jagan@amarulasolutions.com>
Tue, 3 Aug 2021 06:20:37 +0000 (11:50 +0530)
When slave drivers don't set the max_read_size, the spi-mem should
directly use data.nbytes and not limit to any size. But current
logic will limit to the max_write_size.

This commit mirrors the same changes in the dm version done in
commit 535b1fdb8e5e ("spi: spi-mem: Fix read data size issue").

Signed-off-by: Bin Meng <bmeng.cn@gmail.com>
Reviewed-by: Jagan Teki <jagan@amarulasolutions.com>
drivers/spi/spi-mem-nodm.c

index a228c80..77ddb19 100644 (file)
@@ -93,12 +93,14 @@ int spi_mem_adjust_op_size(struct spi_slave *slave,
        if (slave->max_write_size && len > slave->max_write_size)
                return -EINVAL;
 
-       if (op->data.dir == SPI_MEM_DATA_IN && slave->max_read_size)
-               op->data.nbytes = min(op->data.nbytes,
-                                     slave->max_read_size);
-       else if (slave->max_write_size)
+       if (op->data.dir == SPI_MEM_DATA_IN) {
+               if (slave->max_read_size)
+                       op->data.nbytes = min(op->data.nbytes,
+                                             slave->max_read_size);
+       } else if (slave->max_write_size) {
                op->data.nbytes = min(op->data.nbytes,
                                      slave->max_write_size - len);
+       }
 
        if (!op->data.nbytes)
                return -EINVAL;