aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/mtd/ubi/vmt.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/mtd/ubi/vmt.c')
-rw-r--r--drivers/mtd/ubi/vmt.c73
1 files changed, 37 insertions, 36 deletions
diff --git a/drivers/mtd/ubi/vmt.c b/drivers/mtd/ubi/vmt.c
index bfa7c5d2e064..2cd886a5adac 100644
--- a/drivers/mtd/ubi/vmt.c
+++ b/drivers/mtd/ubi/vmt.c
@@ -28,9 +28,9 @@
28#include "ubi.h" 28#include "ubi.h"
29 29
30#ifdef CONFIG_MTD_UBI_DEBUG_PARANOID 30#ifdef CONFIG_MTD_UBI_DEBUG_PARANOID
31static void paranoid_check_volumes(struct ubi_device *ubi); 31static int paranoid_check_volumes(struct ubi_device *ubi);
32#else 32#else
33#define paranoid_check_volumes(ubi) 33#define paranoid_check_volumes(ubi) 0
34#endif 34#endif
35 35
36static ssize_t vol_attribute_show(struct device *dev, 36static ssize_t vol_attribute_show(struct device *dev,
@@ -218,7 +218,7 @@ int ubi_create_volume(struct ubi_device *ubi, struct ubi_mkvol_req *req)
218 spin_lock(&ubi->volumes_lock); 218 spin_lock(&ubi->volumes_lock);
219 if (vol_id == UBI_VOL_NUM_AUTO) { 219 if (vol_id == UBI_VOL_NUM_AUTO) {
220 /* Find unused volume ID */ 220 /* Find unused volume ID */
221 dbg_msg("search for vacant volume ID"); 221 dbg_gen("search for vacant volume ID");
222 for (i = 0; i < ubi->vtbl_slots; i++) 222 for (i = 0; i < ubi->vtbl_slots; i++)
223 if (!ubi->volumes[i]) { 223 if (!ubi->volumes[i]) {
224 vol_id = i; 224 vol_id = i;
@@ -233,7 +233,7 @@ int ubi_create_volume(struct ubi_device *ubi, struct ubi_mkvol_req *req)
233 req->vol_id = vol_id; 233 req->vol_id = vol_id;
234 } 234 }
235 235
236 dbg_msg("volume ID %d, %llu bytes, type %d, name %s", 236 dbg_gen("volume ID %d, %llu bytes, type %d, name %s",
237 vol_id, (unsigned long long)req->bytes, 237 vol_id, (unsigned long long)req->bytes,
238 (int)req->vol_type, req->name); 238 (int)req->vol_type, req->name);
239 239
@@ -361,8 +361,8 @@ int ubi_create_volume(struct ubi_device *ubi, struct ubi_mkvol_req *req)
361 ubi->vol_count += 1; 361 ubi->vol_count += 1;
362 spin_unlock(&ubi->volumes_lock); 362 spin_unlock(&ubi->volumes_lock);
363 363
364 paranoid_check_volumes(ubi); 364 err = paranoid_check_volumes(ubi);
365 return 0; 365 return err;
366 366
367out_sysfs: 367out_sysfs:
368 /* 368 /*
@@ -414,7 +414,7 @@ int ubi_remove_volume(struct ubi_volume_desc *desc)
414 struct ubi_device *ubi = vol->ubi; 414 struct ubi_device *ubi = vol->ubi;
415 int i, err, vol_id = vol->vol_id, reserved_pebs = vol->reserved_pebs; 415 int i, err, vol_id = vol->vol_id, reserved_pebs = vol->reserved_pebs;
416 416
417 dbg_msg("remove UBI volume %d", vol_id); 417 dbg_gen("remove UBI volume %d", vol_id);
418 ubi_assert(desc->mode == UBI_EXCLUSIVE); 418 ubi_assert(desc->mode == UBI_EXCLUSIVE);
419 ubi_assert(vol == ubi->volumes[vol_id]); 419 ubi_assert(vol == ubi->volumes[vol_id]);
420 420
@@ -465,8 +465,8 @@ int ubi_remove_volume(struct ubi_volume_desc *desc)
465 ubi->vol_count -= 1; 465 ubi->vol_count -= 1;
466 spin_unlock(&ubi->volumes_lock); 466 spin_unlock(&ubi->volumes_lock);
467 467
468 paranoid_check_volumes(ubi); 468 err = paranoid_check_volumes(ubi);
469 return 0; 469 return err;
470 470
471out_err: 471out_err:
472 ubi_err("cannot remove volume %d, error %d", vol_id, err); 472 ubi_err("cannot remove volume %d, error %d", vol_id, err);
@@ -497,7 +497,7 @@ int ubi_resize_volume(struct ubi_volume_desc *desc, int reserved_pebs)
497 if (ubi->ro_mode) 497 if (ubi->ro_mode)
498 return -EROFS; 498 return -EROFS;
499 499
500 dbg_msg("re-size volume %d to from %d to %d PEBs", 500 dbg_gen("re-size volume %d to from %d to %d PEBs",
501 vol_id, vol->reserved_pebs, reserved_pebs); 501 vol_id, vol->reserved_pebs, reserved_pebs);
502 502
503 if (vol->vol_type == UBI_STATIC_VOLUME && 503 if (vol->vol_type == UBI_STATIC_VOLUME &&
@@ -586,8 +586,8 @@ int ubi_resize_volume(struct ubi_volume_desc *desc, int reserved_pebs)
586 (long long)vol->used_ebs * vol->usable_leb_size; 586 (long long)vol->used_ebs * vol->usable_leb_size;
587 } 587 }
588 588
589 paranoid_check_volumes(ubi); 589 err = paranoid_check_volumes(ubi);
590 return 0; 590 return err;
591 591
592out_acc: 592out_acc:
593 if (pebs > 0) { 593 if (pebs > 0) {
@@ -615,8 +615,7 @@ int ubi_add_volume(struct ubi_device *ubi, struct ubi_volume *vol)
615 int err, vol_id = vol->vol_id; 615 int err, vol_id = vol->vol_id;
616 dev_t dev; 616 dev_t dev;
617 617
618 dbg_msg("add volume %d", vol_id); 618 dbg_gen("add volume %d", vol_id);
619 ubi_dbg_dump_vol_info(vol);
620 619
621 /* Register character device for the volume */ 620 /* Register character device for the volume */
622 cdev_init(&vol->cdev, &ubi_vol_cdev_operations); 621 cdev_init(&vol->cdev, &ubi_vol_cdev_operations);
@@ -650,8 +649,8 @@ int ubi_add_volume(struct ubi_device *ubi, struct ubi_volume *vol)
650 return err; 649 return err;
651 } 650 }
652 651
653 paranoid_check_volumes(ubi); 652 err = paranoid_check_volumes(ubi);
654 return 0; 653 return err;
655 654
656out_gluebi: 655out_gluebi:
657 err = ubi_destroy_gluebi(vol); 656 err = ubi_destroy_gluebi(vol);
@@ -672,7 +671,7 @@ void ubi_free_volume(struct ubi_device *ubi, struct ubi_volume *vol)
672{ 671{
673 int err; 672 int err;
674 673
675 dbg_msg("free volume %d", vol->vol_id); 674 dbg_gen("free volume %d", vol->vol_id);
676 675
677 ubi->volumes[vol->vol_id] = NULL; 676 ubi->volumes[vol->vol_id] = NULL;
678 err = ubi_destroy_gluebi(vol); 677 err = ubi_destroy_gluebi(vol);
@@ -686,8 +685,10 @@ void ubi_free_volume(struct ubi_device *ubi, struct ubi_volume *vol)
686 * paranoid_check_volume - check volume information. 685 * paranoid_check_volume - check volume information.
687 * @ubi: UBI device description object 686 * @ubi: UBI device description object
688 * @vol_id: volume ID 687 * @vol_id: volume ID
688 *
689 * Returns zero if volume is all right and a a negative error code if not.
689 */ 690 */
690static void paranoid_check_volume(struct ubi_device *ubi, int vol_id) 691static int paranoid_check_volume(struct ubi_device *ubi, int vol_id)
691{ 692{
692 int idx = vol_id2idx(ubi, vol_id); 693 int idx = vol_id2idx(ubi, vol_id);
693 int reserved_pebs, alignment, data_pad, vol_type, name_len, upd_marker; 694 int reserved_pebs, alignment, data_pad, vol_type, name_len, upd_marker;
@@ -705,16 +706,7 @@ static void paranoid_check_volume(struct ubi_device *ubi, int vol_id)
705 goto fail; 706 goto fail;
706 } 707 }
707 spin_unlock(&ubi->volumes_lock); 708 spin_unlock(&ubi->volumes_lock);
708 return; 709 return 0;
709 }
710
711 if (vol->exclusive) {
712 /*
713 * The volume may be being created at the moment, do not check
714 * it (e.g., it may be in the middle of ubi_create_volume().
715 */
716 spin_unlock(&ubi->volumes_lock);
717 return;
718 } 710 }
719 711
720 if (vol->reserved_pebs < 0 || vol->alignment < 0 || vol->data_pad < 0 || 712 if (vol->reserved_pebs < 0 || vol->alignment < 0 || vol->data_pad < 0 ||
@@ -830,25 +822,34 @@ static void paranoid_check_volume(struct ubi_device *ubi, int vol_id)
830 } 822 }
831 823
832 spin_unlock(&ubi->volumes_lock); 824 spin_unlock(&ubi->volumes_lock);
833 return; 825 return 0;
834 826
835fail: 827fail:
836 ubi_err("paranoid check failed for volume %d", vol_id); 828 ubi_err("paranoid check failed for volume %d", vol_id);
837 ubi_dbg_dump_vol_info(vol); 829 if (vol) {
838 ubi_dbg_dump_vtbl_record(&ubi->vtbl[vol_id], vol_id); 830 ubi_dbg_dump_vol_info(vol);
831 ubi_dbg_dump_vtbl_record(&ubi->vtbl[vol_id], vol_id);
832 }
839 spin_unlock(&ubi->volumes_lock); 833 spin_unlock(&ubi->volumes_lock);
840 BUG(); 834 return -EINVAL;
841} 835}
842 836
843/** 837/**
844 * paranoid_check_volumes - check information about all volumes. 838 * paranoid_check_volumes - check information about all volumes.
845 * @ubi: UBI device description object 839 * @ubi: UBI device description object
840 *
841 * Returns zero if volumes are all right and a a negative error code if not.
846 */ 842 */
847static void paranoid_check_volumes(struct ubi_device *ubi) 843static int paranoid_check_volumes(struct ubi_device *ubi)
848{ 844{
849 int i; 845 int i, err = 0;
850 846
851 for (i = 0; i < ubi->vtbl_slots; i++) 847 for (i = 0; i < ubi->vtbl_slots; i++) {
852 paranoid_check_volume(ubi, i); 848 err = paranoid_check_volume(ubi, i);
849 if (err)
850 break;
851 }
852
853 return err;
853} 854}
854#endif 855#endif