]> git.kernelconcepts.de Git - karo-tx-linux.git/commitdiff
ENGR00279980 ubi: attach: do not return -EINVAL if the mtd->numeraseregions is 1
authorHuang Shijie <b32955@freescale.com>
Wed, 18 Sep 2013 02:17:39 +0000 (10:17 +0800)
committerAllen Xu <b45815@freescale.com>
Fri, 30 Jan 2015 19:40:08 +0000 (03:40 +0800)
If the master mtd does not have any slave mtd partitions,
and its numeraseregions is one(only has one erease block), and
we attach the master mtd with : ubiattach -m 0 -d 0

We will meet the error:
-------------------------------------------------------
root@freescale ~$ ubiattach /dev/ubi_ctrl -m 0 -d 0
UBI: attaching mtd0 to ubi0
UBI error: io_init: multiple regions, not implemented
ubiattach: error!: cannot attach mtd0
           error 22 (Invalid argument)
-------------------------------------------------------

In fact, if there is only one "erase block", we should not
prevent the attach.

This patch fixes it.

Signed-off-by: Huang Shijie <b32955@freescale.com>
(cherry picked from commit 361cdc47fc4c4db31c5485560cdabd94f409bd81)

drivers/mtd/ubi/build.c

index 57deae961429d0a161de940072cbc24dc984a008..a5edc646c43a842ede65d94b747f87059aa26bcc 100644 (file)
@@ -640,7 +640,7 @@ static int io_init(struct ubi_device *ubi, int max_beb_per1024)
        dbg_gen("sizeof(struct ubi_ainf_peb) %zu", sizeof(struct ubi_ainf_peb));
        dbg_gen("sizeof(struct ubi_wl_entry) %zu", sizeof(struct ubi_wl_entry));
 
-       if (ubi->mtd->numeraseregions != 0) {
+       if (ubi->mtd->numeraseregions > 1) {
                /*
                 * Some flashes have several erase regions. Different regions
                 * may have different eraseblock size and other