diff options
author | Hou Tao <houtao1@huawei.com> | 2019-11-30 12:48:00 +0300 |
---|---|---|
committer | Richard Weinberger <richard@nod.at> | 2020-01-17 01:35:48 +0300 |
commit | 9d6c4742f96cc0380a3f2854d62c667b87736d71 (patch) | |
tree | 962775ce734d04406487aaf35a3cfac356608de7 /drivers/mtd/ubi | |
parent | 219b0e2cba4ec326f88a08a5c9ad51103089bdab (diff) | |
download | linux-9d6c4742f96cc0380a3f2854d62c667b87736d71.tar.xz |
ubi: Check the presence of volume before call ubi_fastmap_destroy_checkmap()
Else there may be oops when fastmap is enabled and init_volumes() fails.
Signed-off-by: Hou Tao <houtao1@huawei.com>
Signed-off-by: Richard Weinberger <richard@nod.at>
Diffstat (limited to 'drivers/mtd/ubi')
-rw-r--r-- | drivers/mtd/ubi/vtbl.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/mtd/ubi/vtbl.c b/drivers/mtd/ubi/vtbl.c index 53d8ab54e181..8a2a0f091598 100644 --- a/drivers/mtd/ubi/vtbl.c +++ b/drivers/mtd/ubi/vtbl.c @@ -852,6 +852,8 @@ int ubi_read_volume_table(struct ubi_device *ubi, struct ubi_attach_info *ai) out_free: vfree(ubi->vtbl); for (i = 0; i < ubi->vtbl_slots + UBI_INT_VOL_COUNT; i++) { + if (!ubi->volumes[i]) + continue; ubi_fastmap_destroy_checkmap(ubi->volumes[i]); kfree(ubi->volumes[i]); ubi->volumes[i] = NULL; |