Rewrite the code to make it clear exactly where the
SNOR_F_HAS_PARALLEL flag leads to *2 and /2 operation
compared to regular code path. No functional change.

Fixes: 5d40b3d384dc ("mtd: spi-nor: Add parallel and stacked memories support")
Signed-off-by: Marek Vasut <[email protected]>
---
Cc: Andre Przywara <[email protected]>
Cc: Ashok Reddy Soma <[email protected]>
Cc: Jagan Teki <[email protected]>
Cc: Michael Walle <[email protected]>
Cc: Michal Simek <[email protected]>
Cc: Patrice Chotard <[email protected]>
Cc: Patrick Delaunay <[email protected]>
Cc: Pratyush Yadav <[email protected]>
Cc: Quentin Schulz <[email protected]>
Cc: Sean Anderson <[email protected]>
Cc: Simon Glass <[email protected]>
Cc: Takahiro Kuwano <[email protected]>
Cc: Tom Rini <[email protected]>
Cc: Tudor Ambarus <[email protected]>
Cc: Venkatesh Yadav Abbarapu <[email protected]>
Cc: [email protected]
Cc: [email protected]
---
 drivers/mtd/spi/spi-nor-core.c | 15 ++++++++-------
 1 file changed, 8 insertions(+), 7 deletions(-)

diff --git a/drivers/mtd/spi/spi-nor-core.c b/drivers/mtd/spi/spi-nor-core.c
index e49b7cad023..c1ee466bcc0 100644
--- a/drivers/mtd/spi/spi-nor-core.c
+++ b/drivers/mtd/spi/spi-nor-core.c
@@ -1593,13 +1593,14 @@ static int spi_nor_read(struct mtd_info *mtd, loff_t 
from, size_t len,
        }
 
        while (len) {
-               if (nor->flags & SNOR_F_HAS_PARALLEL) {
-                       bank = (u32)from / (SZ_16M << 0x01);
-                       rem_bank_len = ((SZ_16M << 0x01) * (bank + 1)) - from;
-               } else {
-                       bank = (u32)from / SZ_16M;
-                       rem_bank_len = (SZ_16M * (bank + 1)) - from;
-               }
+               bank = (u32)from / SZ_16M;
+               if (nor->flags & SNOR_F_HAS_PARALLEL)
+                       bank /= 2;
+
+               rem_bank_len = SZ_16M * (bank + 1);
+               if (nor->flags & SNOR_F_HAS_PARALLEL)
+                       rem_bank_len *= 2;
+               rem_bank_len -= from;
 
                offset = from;
 
-- 
2.45.2

Reply via email to