1. 21 10月, 2010 1 次提交
    • A
      UBI: remember copy_flag while scanning · fb22b59b
      Artem Bityutskiy 提交于
      While scanning the flash we read all VID headers and store some important
      information in 'struct ubi_scan_leb'. Store also the 'copy_flag' value there
      as it is needed when comparing LEBs. We do not increase memory consumption
      because this is just one bit and we have plenty of spare bits in
      'struct ubi_scan_leb' (sizeof(struct ubi_scan_leb) is 48 both with and
      without this patch).
      Signed-off-by: NArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
      fb22b59b
  2. 19 10月, 2010 2 次提交
    • A
      UBI: do not put eraseblocks to the corrupted list unnecessarily · 0525dac9
      Artem Bityutskiy 提交于
      Currently UBI maintains 2 lists of PEBs during scanning:
      1. 'erase' list - PEBs which have no corruptions but should be erased
      2. 'corr' list - PEBs which have some corruptions and should be erased
      
      But we do not really need 2 lists for PEBs which should be erased after
      scanning is done - this is redundant. So this patch makes sure all PEBs
      which are corrupted are moved to the head of the 'erase' list. We add
      them to the head to make sure they are erased first and we get rid of
      corruption ASAP.
      
      However, we do not remove the 'corr' list and realted functions, because
      the plan is to use this list for other purposes. Namely, we plan to
      put eraseblocks with corruption which does not look like it was caused
      by unclean power cut. Then we'll preserve thes PEBs in order to avoid
      killing potentially valuable user data.
      
      This patch also amends PEBs accounting, because it was closely tight to
      the 'erase'/'corr' lists separation.
      Signed-off-by: NArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
      0525dac9
    • A
      UBI: rename IO error code · 756e1df1
      Artem Bityutskiy 提交于
      Rename UBI_IO_BAD_HDR_READ into UBI_IO_BAD_HDR_EBADMSG which is presumably more
      self-documenting and readable. Indeed, the '_READ' suffix does not tell much and
      even confuses, while '_EBADMSG' tells about uncorrectable ECC error, because we
      use -EBADMSG all over the place to represent ECC errors.
      Signed-off-by: NArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
      756e1df1
  3. 04 6月, 2010 1 次提交
  4. 20 10月, 2009 1 次提交
    • A
      UBI: fix backward compatibility · 2eadaad6
      Artem Bityutskiy 提交于
      Commit 32bc4820 did not fully fix
      the backward compatibility issues. We still fail to properly handle
      situations when the first PEB contains non-zero image sequence
      number, but one of the following PEBs contains zero image sequence
      number. For example, this may happen if we mount a new image with
      an old kernel, and then try to mount it in the new kernel.
      
      This patch should fix the issue.
      Signed-off-by: NArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
      2eadaad6
  5. 15 8月, 2009 1 次提交
    • A
      UBI: print a warning if too many PEBs are corrupted · 4a406856
      Artem Bityutskiy 提交于
      There was a bug report recently where UBI prints:
      
      UBI error: ubi_attach_mtd_dev: failed to attach by scanning, error -22
      
      error messages and refuses to attach a PEB. It turned out to be a
      buggy flash driver which returned garbage to almost every UBI read.
      This patch makes UBI print a better message in such cases. Namely,
      if UBI finds 8 or more corrupted PEBs, it prints a warning and
      lists the corrupted PEBs.
      Signed-off-by: NArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
      4a406856
  6. 05 7月, 2009 1 次提交
  7. 24 7月, 2008 2 次提交
    • A
      UBI: remove pre-sqnum images support · 9869cd80
      Artem Bityutskiy 提交于
      Before UBI got into mainline, there was a slight flash format
      change - we did not have sequence number support, then added it.
      
      We have carried full support of those ancient images till this
      moment. Now the support is removed, well, not fully removed.
      
      Now UBI will support only _clean_ old images, which were cleanly
      detached last time (just before kernel upgrade). This is most
      likely the case.
      
      But we will not support unclean ancient images. Surprisingly,
      this allows us to remove a big chunk of legacy code.
      
      And the same should be true for downgrading: clean images should
      downgrade fine, but unclean ones will not.
      Signed-off-by: NArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
      9869cd80
    • A
      UBI: amend commentaries · 85c6e6e2
      Artem Bityutskiy 提交于
      Hch asked not to use "unit" for sub-systems, let it be so.
      Also some other commentaries modifications.
      Signed-off-by: NArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
      85c6e6e2
  8. 20 4月, 2008 1 次提交
  9. 14 10月, 2007 1 次提交
    • A
      UBI: do not use vmalloc on I/O path · e88d6e10
      Artem Bityutskiy 提交于
      Similar reason as in case of the previous patch: it causes
      deadlocks if a filesystem with writeback support works on top
      of UBI. So pre-allocate needed buffers when attaching MTD device.
      We also need mutexes to protect the buffers, but they do not
      cause much contantion because they are used in recovery, torture,
      and WL copy routines, which are called seldom.
      Signed-off-by: NArtem Bityutskiy <Artem.Bityutskiy@nokia.com>
      e88d6e10
  10. 18 7月, 2007 1 次提交
  11. 27 4月, 2007 1 次提交
    • A
      UBI: Unsorted Block Images · 801c135c
      Artem B. Bityutskiy 提交于
      UBI (Latin: "where?") manages multiple logical volumes on a single
      flash device, specifically supporting NAND flash devices. UBI provides
      a flexible partitioning concept which still allows for wear-levelling
      across the whole flash device.
      
      In a sense, UBI may be compared to the Logical Volume Manager
      (LVM). Whereas LVM maps logical sector numbers to physical HDD sector
      numbers, UBI maps logical eraseblocks to physical eraseblocks.
      
      More information may be found at
      http://www.linux-mtd.infradead.org/doc/ubi.html
      
      Partitioning/Re-partitioning
      
        An UBI volume occupies a certain number of erase blocks. This is
        limited by a configured maximum volume size, which could also be
        viewed as the partition size. Each individual UBI volume's size can
        be changed independently of the other UBI volumes, provided that the
        sum of all volume sizes doesn't exceed a certain limit.
      
        UBI supports dynamic volumes and static volumes. Static volumes are
        read-only and their contents are protected by CRC check sums.
      
      Bad eraseblocks handling
      
        UBI transparently handles bad eraseblocks. When a physical
        eraseblock becomes bad, it is substituted by a good physical
        eraseblock, and the user does not even notice this.
      
      Scrubbing
      
        On a NAND flash bit flips can occur on any write operation,
        sometimes also on read. If bit flips persist on the device, at first
        they can still be corrected by ECC, but once they accumulate,
        correction will become impossible. Thus it is best to actively scrub
        the affected eraseblock, by first copying it to a free eraseblock
        and then erasing the original. The UBI layer performs this type of
        scrubbing under the covers, transparently to the UBI volume users.
      
      Erase Counts
      
        UBI maintains an erase count header per eraseblock. This frees
        higher-level layers (like file systems) from doing this and allows
        for centralized erase count management instead. The erase counts are
        used by the wear-levelling algorithm in the UBI layer. The algorithm
        itself is exchangeable.
      
      Booting from NAND
      
        For booting directly from NAND flash the hardware must at least be
        capable of fetching and executing a small portion of the NAND
        flash. Some NAND flash controllers have this kind of support. They
        usually limit the window to a few kilobytes in erase block 0. This
        "initial program loader" (IPL) must then contain sufficient logic to
        load and execute the next boot phase.
      
        Due to bad eraseblocks, which may be randomly scattered over the
        flash device, it is problematic to store the "secondary program
        loader" (SPL) statically. Also, due to bit-flips it may become
        corrupted over time. UBI allows to solve this problem gracefully by
        storing the SPL in a small static UBI volume.
      
      UBI volumes vs. static partitions
      
        UBI volumes are still very similar to static MTD partitions:
      
          * both consist of eraseblocks (logical eraseblocks in case of UBI
            volumes, and physical eraseblocks in case of static partitions;
          * both support three basic operations - read, write, erase.
      
        But UBI volumes have the following advantages over traditional
        static MTD partitions:
      
          * there are no eraseblock wear-leveling constraints in case of UBI
            volumes, so the user should not care about this;
          * there are no bit-flips and bad eraseblocks in case of UBI volumes.
      
        So, UBI volumes may be considered as flash devices with relaxed
        restrictions.
      
      Where can it be found?
      
        Documentation, kernel code and applications can be found in the MTD
        gits.
      
      What are the applications for?
      
        The applications help to create binary flash images for two purposes: pfi
        files (partial flash images) for in-system update of UBI volumes, and plain
        binary images, with or without OOB data in case of NAND, for a manufacturing
        step. Furthermore some tools are/and will be created that allow flash content
        analysis after a system has crashed..
      
      Who did UBI?
      
        The original ideas, where UBI is based on, were developed by Andreas
        Arnez, Frank Haverkamp and Thomas Gleixner. Josh W. Boyer and some others
        were involved too. The implementation of the kernel layer was done by Artem
        B. Bityutskiy. The user-space applications and tools were written by Oliver
        Lohmann with contributions from Frank Haverkamp, Andreas Arnez, and Artem.
        Joern Engel contributed a patch which modifies JFFS2 so that it can be run on
        a UBI volume. Thomas Gleixner did modifications to the NAND layer. Alexander
        Schmidt made some testing work as well as core functionality improvements.
      Signed-off-by: NArtem B. Bityutskiy <dedekind@linutronix.de>
      Signed-off-by: NFrank Haverkamp <haver@vnet.ibm.com>
      801c135c