]> git.hungrycats.org Git - linux/commitdiff
UBI: return ENOSPC if no enough space available
authorshengyong <shengyong1@huawei.com>
Mon, 28 Sep 2015 17:57:19 +0000 (17:57 +0000)
committerSasha Levin <sasha.levin@oracle.com>
Wed, 28 Oct 2015 02:14:16 +0000 (22:14 -0400)
[ Upstream commit 7c7feb2ebfc9c0552c51f0c050db1d1a004faac5 ]

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.

Cc: stable@vger.kernel.org
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: Sasha Levin <sasha.levin@oracle.com>
drivers/mtd/ubi/vtbl.c
drivers/mtd/ubi/wl.c

index 07cac5f9ffb801f4d3acc8c2c5638d9617638097..ec1009407fecbf694c75acb60ea93ae0ea08746c 100644 (file)
@@ -651,6 +651,7 @@ static int init_volumes(struct ubi_device *ubi,
                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 ef670560971e7ce37750fad49c73920edfc790f9..21d03130d8a70a0058cdd5bef8df2cb910f044a1 100644 (file)
@@ -1982,6 +1982,7 @@ int ubi_wl_init(struct ubi_device *ubi, struct ubi_attach_info *ai)
                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 -= reserved_pebs;