]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
mtd: spi-nor: Check bus width while setting QE bit
authorHsin-Yi Wang <hsinyi@chromium.org>
Fri, 18 Aug 2023 06:42:23 +0000 (14:42 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Wed, 13 Sep 2023 07:48:36 +0000 (09:48 +0200)
[ Upstream commit f01d8155a92e33cdaa85d20bfbe6c441907b3c1f ]

spi_nor_write_16bit_sr_and_check() should also check if bus width is
4 before setting QE bit.

Fixes: 39d1e3340c73 ("mtd: spi-nor: Fix clearing of QE bit on lock()/unlock()")
Suggested-by: Michael Walle <michael@walle.cc>
Suggested-by: Tudor Ambarus <tudor.ambarus@linaro.org>
Signed-off-by: Hsin-Yi Wang <hsinyi@chromium.org>
Reviewed-by: Michael Walle <michael@walle.cc>
Link: https://lore.kernel.org/r/20230818064524.1229100-2-hsinyi@chromium.org
Signed-off-by: Tudor Ambarus <tudor.ambarus@linaro.org>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/mtd/spi-nor/core.c

index 5f29fac8669a301e8010566eee02edfdcdb66620..55f4a902b8be922fc71fbc694d34cd5fd6a9c2e5 100644 (file)
@@ -870,21 +870,22 @@ static int spi_nor_write_16bit_sr_and_check(struct spi_nor *nor, u8 sr1)
                ret = spi_nor_read_cr(nor, &sr_cr[1]);
                if (ret)
                        return ret;
-       } else if (nor->params->quad_enable) {
+       } else if (spi_nor_get_protocol_width(nor->read_proto) == 4 &&
+                  spi_nor_get_protocol_width(nor->write_proto) == 4 &&
+                  nor->params->quad_enable) {
                /*
                 * If the Status Register 2 Read command (35h) is not
                 * supported, we should at least be sure we don't
                 * change the value of the SR2 Quad Enable bit.
                 *
-                * We can safely assume that when the Quad Enable method is
-                * set, the value of the QE bit is one, as a consequence of the
-                * nor->params->quad_enable() call.
+                * When the Quad Enable method is set and the buswidth is 4, we
+                * can safely assume that the value of the QE bit is one, as a
+                * consequence of the nor->params->quad_enable() call.
                 *
-                * We can safely assume that the Quad Enable bit is present in
-                * the Status Register 2 at BIT(1). According to the JESD216
-                * revB standard, BFPT DWORDS[15], bits 22:20, the 16-bit
-                * Write Status (01h) command is available just for the cases
-                * in which the QE bit is described in SR2 at BIT(1).
+                * According to the JESD216 revB standard, BFPT DWORDS[15],
+                * bits 22:20, the 16-bit Write Status (01h) command is
+                * available just for the cases in which the QE bit is
+                * described in SR2 at BIT(1).
                 */
                sr_cr[1] = SR2_QUAD_EN_BIT1;
        } else {