diff options
Diffstat (limited to 'drivers/mtd/ubi/scan.c')
-rw-r--r-- | drivers/mtd/ubi/scan.c | 45 |
1 files changed, 32 insertions, 13 deletions
diff --git a/drivers/mtd/ubi/scan.c b/drivers/mtd/ubi/scan.c index a15e9bcb6e77..9405e2420055 100644 --- a/drivers/mtd/ubi/scan.c +++ b/drivers/mtd/ubi/scan.c | |||
@@ -746,11 +746,18 @@ static int process_eb(struct ubi_device *ubi, struct ubi_scan_info *si, | |||
746 | err = ubi_io_read_ec_hdr(ubi, pnum, ech, 0); | 746 | err = ubi_io_read_ec_hdr(ubi, pnum, ech, 0); |
747 | if (err < 0) | 747 | if (err < 0) |
748 | return err; | 748 | return err; |
749 | else if (err == UBI_IO_BITFLIPS) | 749 | switch (err) { |
750 | case 0: | ||
751 | break; | ||
752 | case UBI_IO_BITFLIPS: | ||
750 | bitflips = 1; | 753 | bitflips = 1; |
751 | else if (err == UBI_IO_FF || err == UBI_IO_FF_BITFLIPS) | 754 | break; |
755 | case UBI_IO_FF: | ||
756 | case UBI_IO_FF_BITFLIPS: | ||
752 | return add_to_list(si, pnum, UBI_SCAN_UNKNOWN_EC, &si->erase); | 757 | return add_to_list(si, pnum, UBI_SCAN_UNKNOWN_EC, &si->erase); |
753 | else if (err == UBI_IO_BAD_HDR_EBADMSG || err == UBI_IO_BAD_HDR) { | 758 | case UBI_IO_BAD_HDR_EBADMSG: |
759 | si->read_err_count += 1; | ||
760 | case UBI_IO_BAD_HDR: | ||
754 | /* | 761 | /* |
755 | * We have to also look at the VID header, possibly it is not | 762 | * We have to also look at the VID header, possibly it is not |
756 | * corrupted. Set %bitflips flag in order to make this PEB be | 763 | * corrupted. Set %bitflips flag in order to make this PEB be |
@@ -759,6 +766,10 @@ static int process_eb(struct ubi_device *ubi, struct ubi_scan_info *si, | |||
759 | ec_err = err; | 766 | ec_err = err; |
760 | ec = UBI_SCAN_UNKNOWN_EC; | 767 | ec = UBI_SCAN_UNKNOWN_EC; |
761 | bitflips = 1; | 768 | bitflips = 1; |
769 | break; | ||
770 | default: | ||
771 | ubi_err("'ubi_io_read_ec_hdr()' returned unknown code %d", err); | ||
772 | return -EINVAL; | ||
762 | } | 773 | } |
763 | 774 | ||
764 | if (!ec_err) { | 775 | if (!ec_err) { |
@@ -814,24 +825,32 @@ static int process_eb(struct ubi_device *ubi, struct ubi_scan_info *si, | |||
814 | err = ubi_io_read_vid_hdr(ubi, pnum, vidh, 0); | 825 | err = ubi_io_read_vid_hdr(ubi, pnum, vidh, 0); |
815 | if (err < 0) | 826 | if (err < 0) |
816 | return err; | 827 | return err; |
817 | else if (err == UBI_IO_BITFLIPS) | 828 | switch (err) { |
829 | case 0: | ||
830 | break; | ||
831 | case UBI_IO_BITFLIPS: | ||
818 | bitflips = 1; | 832 | bitflips = 1; |
819 | else if (err == UBI_IO_BAD_HDR_EBADMSG || err == UBI_IO_BAD_HDR || | 833 | break; |
820 | (err == UBI_IO_FF && ec_err) || err == UBI_IO_FF_BITFLIPS) { | 834 | case UBI_IO_BAD_HDR_EBADMSG: |
821 | /* VID header is corrupted */ | 835 | si->read_err_count += 1; |
822 | if (err == UBI_IO_BAD_HDR_EBADMSG || | 836 | case UBI_IO_BAD_HDR: |
823 | ec_err == UBI_IO_BAD_HDR_EBADMSG) | 837 | case UBI_IO_FF_BITFLIPS: |
824 | si->read_err_count += 1; | ||
825 | err = add_to_list(si, pnum, ec, &si->corr); | 838 | err = add_to_list(si, pnum, ec, &si->corr); |
826 | if (err) | 839 | if (err) |
827 | return err; | 840 | return err; |
828 | goto adjust_mean_ec; | 841 | goto adjust_mean_ec; |
829 | } else if (err == UBI_IO_FF) { | 842 | case UBI_IO_FF: |
830 | /* No VID header - the physical eraseblock is free */ | 843 | if (ec_err) |
831 | err = add_to_list(si, pnum, ec, &si->free); | 844 | err = add_to_list(si, pnum, ec, &si->corr); |
845 | else | ||
846 | err = add_to_list(si, pnum, ec, &si->free); | ||
832 | if (err) | 847 | if (err) |
833 | return err; | 848 | return err; |
834 | goto adjust_mean_ec; | 849 | goto adjust_mean_ec; |
850 | default: | ||
851 | ubi_err("'ubi_io_read_vid_hdr()' returned unknown code %d", | ||
852 | err); | ||
853 | return -EINVAL; | ||
835 | } | 854 | } |
836 | 855 | ||
837 | vol_id = be32_to_cpu(vidh->vol_id); | 856 | vol_id = be32_to_cpu(vidh->vol_id); |