mtd: rawnand: meson: fix unaligned DMA buffers handling
authorArseniy Krasnov <AVKrasnov@sberdevices.ru>
Thu, 15 Jun 2023 08:08:15 +0000 (11:08 +0300)
committerMiquel Raynal <miquel.raynal@bootlin.com>
Mon, 19 Jun 2023 08:20:58 +0000 (10:20 +0200)
Meson NAND controller requires 8 bytes alignment for DMA addresses,
otherwise it "aligns" passed address by itself thus accessing invalid
location in the provided buffer. This patch makes unaligned buffers to
be reallocated to become valid.

Fixes: 8fae856c5350 ("mtd: rawnand: meson: add support for Amlogic NAND flash controller")
Cc: <Stable@vger.kernel.org>
Signed-off-by: Arseniy Krasnov <AVKrasnov@sberdevices.ru>
Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
Link: https://lore.kernel.org/linux-mtd/20230615080815.3291006-1-AVKrasnov@sberdevices.ru
drivers/mtd/nand/raw/meson_nand.c

index 9c3300748efbf4ebdadbd81fedc22df9ec730bae..d3faf80866314622aefbfb9d927124a3ebd72736 100644 (file)
@@ -77,6 +77,7 @@
 #define GENCMDIADDRH(aih, addr)                ((aih) | (((addr) >> 16) & 0xffff))
 
 #define DMA_DIR(dir)           ((dir) ? NFC_CMD_N2M : NFC_CMD_M2N)
+#define DMA_ADDR_ALIGN         8
 
 #define ECC_CHECK_RETURN_FF    (-1)
 
@@ -905,6 +906,9 @@ static int meson_nfc_read_oob(struct nand_chip *nand, int page)
 
 static bool meson_nfc_is_buffer_dma_safe(const void *buffer)
 {
+       if ((uintptr_t)buffer % DMA_ADDR_ALIGN)
+               return false;
+
        if (virt_addr_valid(buffer) && (!object_is_on_stack(buffer)))
                return true;
        return false;