diff mbox

UBI: init_volumes: Ignore volumes with no LEBs

Message ID 1404828284-32643-1-git-send-email-richard@nod.at
State Accepted
Commit e8c235b065ec07cd1c63c0e0bfbfc718d438baba
Headers show

Commit Message

Richard Weinberger July 8, 2014, 2:04 p.m. UTC
UBI assumes that ubi_attach_info will only contain ubi_ainf_volume
structures for volumes with at least one LEB.
In scanning mode this is true because UBI can nicely create a ubi_ainf_volume
on demand while creating the EBA table.

For fastmap this is not true, the fastmap on-flash structure has a list of
all volumes, the ubi_ainf_volume structures are created from this list.
So it can happen that an empty volume ends up in init_volumes().

We can easely deal with that by looking into ->leb_count too.

Signed-off-by: Richard Weinberger <richard@nod.at>
---
 drivers/mtd/ubi/vtbl.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

Comments

Artem Bityutskiy July 16, 2014, 8:31 a.m. UTC | #1
On Tue, 2014-07-08 at 16:04 +0200, Richard Weinberger wrote:
> UBI assumes that ubi_attach_info will only contain ubi_ainf_volume
> structures for volumes with at least one LEB.
> In scanning mode this is true because UBI can nicely create a ubi_ainf_volume
> on demand while creating the EBA table.

Applied to linux-ubifs.git, thanks!
diff mbox

Patch

diff --git a/drivers/mtd/ubi/vtbl.c b/drivers/mtd/ubi/vtbl.c
index d77b1c1..07cac5f 100644
--- a/drivers/mtd/ubi/vtbl.c
+++ b/drivers/mtd/ubi/vtbl.c
@@ -591,7 +591,7 @@  static int init_volumes(struct ubi_device *ubi,
 
 		/* Static volumes only */
 		av = ubi_find_av(ai, i);
-		if (!av) {
+		if (!av || !av->leb_count) {
 			/*
 			 * No eraseblocks belonging to this volume found. We
 			 * don't actually know whether this static volume is