diff options
author | Sebastian Siewior <bigeasy@linutronix.de> | 2015-11-26 21:23:49 +0100 |
---|---|---|
committer | Richard Weinberger <richard@nod.at> | 2015-12-16 22:59:03 +0100 |
commit | 6b238de189f69dc77d660d4cce62eed15547f4c3 (patch) | |
tree | bfc45a51a777327cba3d9ed54b18e5b5e6cc0bb2 /drivers/mtd/ubi/wl.c | |
parent | mtd: ubi: fixup error correction in do_sync_erase() (diff) | |
download | linux-6b238de189f69dc77d660d4cce62eed15547f4c3.tar.xz linux-6b238de189f69dc77d660d4cce62eed15547f4c3.zip |
mtd: ubi: don't leak e if schedule_erase() fails
If __erase_worker() fails to erase the EB and schedule_erase() fails as
well to do anything about it then we go RO. But that is not a reason to
leak the e argument here. Therefore clean up e.
Cc: <stable@vger.kernel.org>
Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
Signed-off-by: Richard Weinberger <richard@nod.at>
Diffstat (limited to 'drivers/mtd/ubi/wl.c')
-rw-r--r-- | drivers/mtd/ubi/wl.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/mtd/ubi/wl.c b/drivers/mtd/ubi/wl.c index f73233fa737c..56065632a5b8 100644 --- a/drivers/mtd/ubi/wl.c +++ b/drivers/mtd/ubi/wl.c @@ -1060,6 +1060,7 @@ static int __erase_worker(struct ubi_device *ubi, struct ubi_work *wl_wrk) /* Re-schedule the LEB for erasure */ err1 = schedule_erase(ubi, e, vol_id, lnum, 0); if (err1) { + wl_entry_destroy(ubi, e); err = err1; goto out_ro; } |