diff options
Diffstat (limited to 'drivers/mtd/ubi')
| -rw-r--r-- | drivers/mtd/ubi/block.c | 2 | ||||
| -rw-r--r-- | drivers/mtd/ubi/wl.c | 6 |
2 files changed, 7 insertions, 1 deletions
diff --git a/drivers/mtd/ubi/block.c b/drivers/mtd/ubi/block.c index 7ff473c871a9..8d659e6a1b4c 100644 --- a/drivers/mtd/ubi/block.c +++ b/drivers/mtd/ubi/block.c | |||
| @@ -431,7 +431,7 @@ int ubiblock_create(struct ubi_volume_info *vi) | |||
| 431 | * Create one workqueue per volume (per registered block device). | 431 | * Create one workqueue per volume (per registered block device). |
| 432 | * Rembember workqueues are cheap, they're not threads. | 432 | * Rembember workqueues are cheap, they're not threads. |
| 433 | */ | 433 | */ |
| 434 | dev->wq = alloc_workqueue(gd->disk_name, 0, 0); | 434 | dev->wq = alloc_workqueue("%s", 0, 0, gd->disk_name); |
| 435 | if (!dev->wq) | 435 | if (!dev->wq) |
| 436 | goto out_free_queue; | 436 | goto out_free_queue; |
| 437 | INIT_WORK(&dev->work, ubiblock_do_work); | 437 | INIT_WORK(&dev->work, ubiblock_do_work); |
diff --git a/drivers/mtd/ubi/wl.c b/drivers/mtd/ubi/wl.c index 02317c1c0238..0f3425dac910 100644 --- a/drivers/mtd/ubi/wl.c +++ b/drivers/mtd/ubi/wl.c | |||
| @@ -671,6 +671,8 @@ static struct ubi_wl_entry *get_peb_for_wl(struct ubi_device *ubi) | |||
| 671 | 671 | ||
| 672 | e = find_wl_entry(ubi, &ubi->free, WL_FREE_MAX_DIFF); | 672 | e = find_wl_entry(ubi, &ubi->free, WL_FREE_MAX_DIFF); |
| 673 | self_check_in_wl_tree(ubi, e, &ubi->free); | 673 | self_check_in_wl_tree(ubi, e, &ubi->free); |
| 674 | ubi->free_count--; | ||
| 675 | ubi_assert(ubi->free_count >= 0); | ||
| 674 | rb_erase(&e->u.rb, &ubi->free); | 676 | rb_erase(&e->u.rb, &ubi->free); |
| 675 | 677 | ||
| 676 | return e; | 678 | return e; |
| @@ -684,6 +686,9 @@ int ubi_wl_get_peb(struct ubi_device *ubi) | |||
| 684 | peb = __wl_get_peb(ubi); | 686 | peb = __wl_get_peb(ubi); |
| 685 | spin_unlock(&ubi->wl_lock); | 687 | spin_unlock(&ubi->wl_lock); |
| 686 | 688 | ||
| 689 | if (peb < 0) | ||
| 690 | return peb; | ||
| 691 | |||
| 687 | err = ubi_self_check_all_ff(ubi, peb, ubi->vid_hdr_aloffset, | 692 | err = ubi_self_check_all_ff(ubi, peb, ubi->vid_hdr_aloffset, |
| 688 | ubi->peb_size - ubi->vid_hdr_aloffset); | 693 | ubi->peb_size - ubi->vid_hdr_aloffset); |
| 689 | if (err) { | 694 | if (err) { |
| @@ -1068,6 +1073,7 @@ static int wear_leveling_worker(struct ubi_device *ubi, struct ubi_work *wrk, | |||
| 1068 | 1073 | ||
| 1069 | /* Give the unused PEB back */ | 1074 | /* Give the unused PEB back */ |
| 1070 | wl_tree_add(e2, &ubi->free); | 1075 | wl_tree_add(e2, &ubi->free); |
| 1076 | ubi->free_count++; | ||
| 1071 | goto out_cancel; | 1077 | goto out_cancel; |
| 1072 | } | 1078 | } |
| 1073 | self_check_in_wl_tree(ubi, e1, &ubi->used); | 1079 | self_check_in_wl_tree(ubi, e1, &ubi->used); |
