[PATCH 1/2] spi: spi-mem: s/dummy/data buswidth check in dtr_supports_op()
Nikhil M Jain
n-jain1 at ti.com
Wed Mar 1 08:43:45 CET 2023
From: Dhruva Gole <d-gole at ti.com>
This should have been op->data.buswidth instead as we check for octal
bus width for the data related ops
Also add explanation for why there is checks for 8D even data bytes
Cc: Pratyush Yadav <pratyush at kernel.org>
Reviewed-by: Pratyush Yadav <ptyadav at amazon.de>
Tested-by: Nikhil M Jain <n-jain1 at ti.com>
Signed-off-by: Dhruva Gole <d-gole at ti.com>
---
This patch has no changes wrt previously sent patch:
https://lore.kernel.org/u-boot/20230220054231.74367-1-d-gole@ti.com/
drivers/spi/spi-mem.c | 6 +++++-
1 file changed, 5 insertions(+), 1 deletion(-)
diff --git a/drivers/spi/spi-mem.c b/drivers/spi/spi-mem.c
index 8e8995fc53..57a36f31a5 100644
--- a/drivers/spi/spi-mem.c
+++ b/drivers/spi/spi-mem.c
@@ -181,8 +181,12 @@ bool spi_mem_dtr_supports_op(struct spi_slave *slave,
if (op->dummy.nbytes && op->dummy.buswidth == 8 && op->dummy.nbytes % 2)
return false;
+ /*
+ * Transactions of odd length do not make sense for 8D-8D-8D mode
+ * because a byte is transferred in just half a cycle.
+ */
if (op->data.dir != SPI_MEM_NO_DATA &&
- op->dummy.buswidth == 8 && op->data.nbytes % 2)
+ op->data.buswidth == 8 && op->data.nbytes % 2)
return false;
return spi_mem_check_buswidth(slave, op);
--
2.34.1
More information about the U-Boot
mailing list