1234567891011121314151617181920212223242526272829303132333435363738394041424344 |
- From 93aa2e2f5af5b8e766fc22c3ff83a1642462025f Mon Sep 17 00:00:00 2001
- From: Heiner Kallweit <hkallweit1@gmail.com>
- Date: Tue, 17 Nov 2015 20:18:54 +0100
- Subject: [PATCH 14/33] mtd: spi-nor: fix error handling in spi_nor_erase
- The documenting comment of mtd_erase in mtdcore.c states:
- Device drivers are supposed to call instr->callback() whenever
- the operation completes, even if it completes with a failure.
- Currently the callback isn't called in case of failure. Fix this.
- Signed-off-by: Heiner Kallweit <hkallweit1@gmail.com>
- Signed-off-by: Brian Norris <computersforpeace@gmail.com>
- ---
- drivers/mtd/spi-nor/spi-nor.c | 8 ++------
- 1 file changed, 2 insertions(+), 6 deletions(-)
- diff --git a/drivers/mtd/spi-nor/spi-nor.c b/drivers/mtd/spi-nor/spi-nor.c
- index 3a50eea..43e00e2 100644
- --- a/drivers/mtd/spi-nor/spi-nor.c
- +++ b/drivers/mtd/spi-nor/spi-nor.c
- @@ -410,17 +410,13 @@ static int spi_nor_erase(struct mtd_info *mtd, struct erase_info *instr)
-
- write_disable(nor);
-
- +erase_err:
- spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_ERASE);
-
- - instr->state = MTD_ERASE_DONE;
- + instr->state = ret ? MTD_ERASE_FAILED : MTD_ERASE_DONE;
- mtd_erase_callback(instr);
-
- return ret;
- -
- -erase_err:
- - spi_nor_unlock_and_unprep(nor, SPI_NOR_OPS_ERASE);
- - instr->state = MTD_ERASE_FAILED;
- - return ret;
- }
-
- static void stm_get_locked_range(struct spi_nor *nor, u8 sr, loff_t *ofs,
- --
- 2.8.1
|