diff options
Diffstat (limited to 'drivers/mtd/ubi/build.c')
-rw-r--r-- | drivers/mtd/ubi/build.c | 42 |
1 files changed, 25 insertions, 17 deletions
diff --git a/drivers/mtd/ubi/build.c b/drivers/mtd/ubi/build.c index 7f6820becf10..9b94427be145 100644 --- a/drivers/mtd/ubi/build.c +++ b/drivers/mtd/ubi/build.c | |||
@@ -58,9 +58,6 @@ static int mtd_devs = 0; | |||
58 | /* MTD devices specification parameters */ | 58 | /* MTD devices specification parameters */ |
59 | static struct mtd_dev_param mtd_dev_param[UBI_MAX_DEVICES]; | 59 | static struct mtd_dev_param mtd_dev_param[UBI_MAX_DEVICES]; |
60 | 60 | ||
61 | /* Number of UBI devices in system */ | ||
62 | int ubi_devices_cnt; | ||
63 | |||
64 | /* All UBI devices in system */ | 61 | /* All UBI devices in system */ |
65 | struct ubi_device *ubi_devices[UBI_MAX_DEVICES]; | 62 | struct ubi_device *ubi_devices[UBI_MAX_DEVICES]; |
66 | 63 | ||
@@ -566,26 +563,39 @@ static int attach_mtd_dev(const char *mtd_dev, int vid_hdr_offset, | |||
566 | } | 563 | } |
567 | 564 | ||
568 | /* Check if we already have the same MTD device attached */ | 565 | /* Check if we already have the same MTD device attached */ |
569 | for (i = 0; i < ubi_devices_cnt; i++) | 566 | for (i = 0; i < UBI_MAX_DEVICES; i++) |
570 | if (ubi_devices[i]->mtd->index == mtd->index) { | 567 | ubi = ubi_devices[i]; |
568 | if (ubi && ubi->mtd->index == mtd->index) { | ||
571 | ubi_err("mtd%d is already attached to ubi%d", | 569 | ubi_err("mtd%d is already attached to ubi%d", |
572 | mtd->index, i); | 570 | mtd->index, i); |
573 | err = -EINVAL; | 571 | err = -EINVAL; |
574 | goto out_mtd; | 572 | goto out_mtd; |
575 | } | 573 | } |
576 | 574 | ||
577 | ubi = ubi_devices[ubi_devices_cnt] = kzalloc(sizeof(struct ubi_device), | 575 | ubi = kzalloc(sizeof(struct ubi_device), GFP_KERNEL); |
578 | GFP_KERNEL); | ||
579 | if (!ubi) { | 576 | if (!ubi) { |
580 | err = -ENOMEM; | 577 | err = -ENOMEM; |
581 | goto out_mtd; | 578 | goto out_mtd; |
582 | } | 579 | } |
583 | 580 | ||
584 | ubi->ubi_num = ubi_devices_cnt; | ||
585 | ubi->mtd = mtd; | 581 | ubi->mtd = mtd; |
586 | 582 | ||
583 | /* Search for an empty slot in the @ubi_devices array */ | ||
584 | ubi->ubi_num = -1; | ||
585 | for (i = 0; i < UBI_MAX_DEVICES; i++) | ||
586 | if (!ubi_devices[i]) { | ||
587 | ubi->ubi_num = i; | ||
588 | break; | ||
589 | } | ||
590 | |||
591 | if (ubi->ubi_num == -1) { | ||
592 | ubi_err("only %d UBI devices may be created", UBI_MAX_DEVICES); | ||
593 | err = -ENFILE; | ||
594 | goto out_free; | ||
595 | } | ||
596 | |||
587 | dbg_msg("attaching mtd%d to ubi%d: VID header offset %d data offset %d", | 597 | dbg_msg("attaching mtd%d to ubi%d: VID header offset %d data offset %d", |
588 | ubi->mtd->index, ubi_devices_cnt, vid_hdr_offset, data_offset); | 598 | ubi->mtd->index, ubi->ubi_num, vid_hdr_offset, data_offset); |
589 | 599 | ||
590 | ubi->vid_hdr_offset = vid_hdr_offset; | 600 | ubi->vid_hdr_offset = vid_hdr_offset; |
591 | ubi->leb_start = data_offset; | 601 | ubi->leb_start = data_offset; |
@@ -619,7 +629,7 @@ static int attach_mtd_dev(const char *mtd_dev, int vid_hdr_offset, | |||
619 | if (err) | 629 | if (err) |
620 | goto out_detach; | 630 | goto out_detach; |
621 | 631 | ||
622 | ubi_msg("attached mtd%d to ubi%d", ubi->mtd->index, ubi_devices_cnt); | 632 | ubi_msg("attached mtd%d to ubi%d", ubi->mtd->index, ubi->ubi_num); |
623 | ubi_msg("MTD device name: \"%s\"", ubi->mtd->name); | 633 | ubi_msg("MTD device name: \"%s\"", ubi->mtd->name); |
624 | ubi_msg("MTD device size: %llu MiB", ubi->flash_size >> 20); | 634 | ubi_msg("MTD device size: %llu MiB", ubi->flash_size >> 20); |
625 | ubi_msg("physical eraseblock size: %d bytes (%d KiB)", | 635 | ubi_msg("physical eraseblock size: %d bytes (%d KiB)", |
@@ -648,7 +658,7 @@ static int attach_mtd_dev(const char *mtd_dev, int vid_hdr_offset, | |||
648 | wake_up_process(ubi->bgt_thread); | 658 | wake_up_process(ubi->bgt_thread); |
649 | } | 659 | } |
650 | 660 | ||
651 | ubi_devices_cnt += 1; | 661 | ubi_devices[ubi->ubi_num] = ubi; |
652 | return 0; | 662 | return 0; |
653 | 663 | ||
654 | out_detach: | 664 | out_detach: |
@@ -664,7 +674,6 @@ out_free: | |||
664 | kfree(ubi); | 674 | kfree(ubi); |
665 | out_mtd: | 675 | out_mtd: |
666 | put_mtd_device(mtd); | 676 | put_mtd_device(mtd); |
667 | ubi_devices[ubi_devices_cnt] = NULL; | ||
668 | return err; | 677 | return err; |
669 | } | 678 | } |
670 | 679 | ||
@@ -689,8 +698,6 @@ static void detach_mtd_dev(struct ubi_device *ubi) | |||
689 | #endif | 698 | #endif |
690 | kfree(ubi_devices[ubi_num]); | 699 | kfree(ubi_devices[ubi_num]); |
691 | ubi_devices[ubi_num] = NULL; | 700 | ubi_devices[ubi_num] = NULL; |
692 | ubi_devices_cnt -= 1; | ||
693 | ubi_assert(ubi_devices_cnt >= 0); | ||
694 | ubi_msg("mtd%d is detached from ubi%d", mtd_num, ubi_num); | 701 | ubi_msg("mtd%d is detached from ubi%d", mtd_num, ubi_num); |
695 | } | 702 | } |
696 | 703 | ||
@@ -770,10 +777,11 @@ module_init(ubi_init); | |||
770 | 777 | ||
771 | static void __exit ubi_exit(void) | 778 | static void __exit ubi_exit(void) |
772 | { | 779 | { |
773 | int i, n = ubi_devices_cnt; | 780 | int i; |
774 | 781 | ||
775 | for (i = 0; i < n; i++) | 782 | for (i = 0; i < UBI_MAX_DEVICES; i++) |
776 | detach_mtd_dev(ubi_devices[i]); | 783 | if (ubi_devices[i]) |
784 | detach_mtd_dev(ubi_devices[i]); | ||
777 | kmem_cache_destroy(ubi_wl_entry_slab); | 785 | kmem_cache_destroy(ubi_wl_entry_slab); |
778 | kmem_cache_destroy(ubi_ltree_slab); | 786 | kmem_cache_destroy(ubi_ltree_slab); |
779 | class_remove_file(ubi_class, &ubi_version); | 787 | class_remove_file(ubi_class, &ubi_version); |