]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
UBI: return ENOSPC if no enough space available
authorshengyong <shengyong1@huawei.com>
Mon, 28 Sep 2015 17:57:19 +0000 (17:57 +0000)
committerZefan Li <lizefan@huawei.com>
Wed, 27 Apr 2016 10:55:25 +0000 (18:55 +0800)
commit 7c7feb2ebfc9c0552c51f0c050db1d1a004faac5 upstream.

UBI: attaching mtd1 to ubi0
UBI: scanning is finished
UBI error: init_volumes: not enough PEBs, required 706, available 686
UBI error: ubi_wl_init: no enough physical eraseblocks (-20, need 1)
UBI error: ubi_attach_mtd_dev: failed to attach mtd1, error -12 <= NOT ENOMEM
UBI error: ubi_init: cannot attach mtd1

If available PEBs are not enough when initializing volumes, return -ENOSPC
directly. If available PEBs are not enough when initializing WL, return
-ENOSPC instead of -ENOMEM.

Signed-off-by: Sheng Yong <shengyong1@huawei.com>
Signed-off-by: Richard Weinberger <richard@nod.at>
Reviewed-by: David Gstir <david@sigma-star.at>
Signed-off-by: Zefan Li <lizefan@huawei.com>
drivers/mtd/ubi/vtbl.c
drivers/mtd/ubi/wl.c

index c015fc0a76d8cdb2e6765c22ed4111c4a1d83e7b..4105a508f215857492685e1fb514e82f67bbef14 100644 (file)
@@ -656,6 +656,7 @@ static int init_volumes(struct ubi_device *ubi, const struct ubi_scan_info *si,
                if (ubi->corr_peb_count)
                        ubi_err("%d PEBs are corrupted and not used",
                                ubi->corr_peb_count);
+               return -ENOSPC;
        }
        ubi->rsvd_pebs += reserved_pebs;
        ubi->avail_pebs -= reserved_pebs;
index 284d144ff5a651dbbb236cb89b25259653999efe..3e42cd6f7c77b1e8972ed2fd4c8276545d64e86c 100644 (file)
@@ -1513,6 +1513,7 @@ int ubi_wl_init_scan(struct ubi_device *ubi, struct ubi_scan_info *si)
                if (ubi->corr_peb_count)
                        ubi_err("%d PEBs are corrupted and not used",
                                ubi->corr_peb_count);
+               err = -ENOSPC;
                goto out_free;
        }
        ubi->avail_pebs -= WL_RESERVED_PEBS;