nand: zynq: Fix driver initialization
authorEzequiel Garcia <ezequiel@vanguardiasur.com.ar>
Fri, 12 Jan 2018 18:30:55 +0000 (15:30 -0300)
committerMichal Simek <michal.simek@xilinx.com>
Mon, 23 Apr 2018 11:15:27 +0000 (13:15 +0200)
This driver is currently broken, refusing to initialize properly.

The reason is that get_nand_dev_by_index() was being called before
nand_register(), thus returning a pointer into uninitialized memory.
In other words, the struct mtd_info used by the driver is total junk.

Fix it by getting the correct struct mtd_info, via nand_to_mtd()
on the driver's struct nand_chip.

Tested on a custom board, where the CPU is halted without this patch.

Signed-off-by: Ezequiel Garcia <ezequiel@vanguardiasur.com.ar>
Reviewed-by: Michal Simek <michal.simek@xilinx.com>
Signed-off-by: Michal Simek <michal.simek@xilinx.com>
drivers/mtd/nand/zynq_nand.c

index 6494196049f1c4a521c40859badfb6144903909d..9f6ff3d045c21d063e39841374a07b6c3197f374 100644 (file)
@@ -1025,7 +1025,7 @@ int zynq_nand_init(struct nand_chip *nand_chip, int devnum)
        }
 
        xnand->nand_base = (void __iomem *)ZYNQ_NAND_BASEADDR;
-       mtd = get_nand_dev_by_index(0);
+       mtd = nand_to_mtd(nand_chip);
 
        nand_chip->priv = xnand;
        mtd->priv = nand_chip;