Commit c3c7dbf4 authored by Boris Brezillon's avatar Boris Brezillon

mtd: spinand: Fix the error/cleanup path in spinand_init()

The manufacturer specific initialization has already been done when
block unlocking takes place, and if anything goes wrong during this
procedure we should call spinand_manufacturer_cleanup().

Fixes: 7529df46 ("mtd: nand: Add core infrastructure to support SPI NANDs")
Cc: <stable@vger.kernel.org>
Signed-off-by: default avatarBoris Brezillon <bbrezillon@kernel.org>
Acked-by: default avatarMiquel Raynal <miquel.raynal@bootlin.com>
parent 13c15e07
...@@ -1016,11 +1016,11 @@ static int spinand_init(struct spinand_device *spinand) ...@@ -1016,11 +1016,11 @@ static int spinand_init(struct spinand_device *spinand)
for (i = 0; i < nand->memorg.ntargets; i++) { for (i = 0; i < nand->memorg.ntargets; i++) {
ret = spinand_select_target(spinand, i); ret = spinand_select_target(spinand, i);
if (ret) if (ret)
goto err_free_bufs; goto err_manuf_cleanup;
ret = spinand_lock_block(spinand, BL_ALL_UNLOCKED); ret = spinand_lock_block(spinand, BL_ALL_UNLOCKED);
if (ret) if (ret)
goto err_free_bufs; goto err_manuf_cleanup;
} }
ret = nanddev_init(nand, &spinand_ops, THIS_MODULE); ret = nanddev_init(nand, &spinand_ops, THIS_MODULE);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment