]> git.dujemihanovic.xyz Git - u-boot.git/commit
nand erase: .spread, .part, .chip subcommands
authorScott Wood <scottwood@freescale.com>
Wed, 25 Aug 2010 19:43:29 +0000 (14:43 -0500)
committerScott Wood <scottwood@freescale.com>
Mon, 11 Oct 2010 20:10:17 +0000 (15:10 -0500)
commit30486322517c99f09eabc53f5fad43063656a4f0
treeaf15251c107a436647938b927b9bf885afae85d6
parentea533c260a801c4e51f92f75165cebe6d7b01e35
nand erase: .spread, .part, .chip subcommands

A while back, in http://lists.denx.de/pipermail/u-boot/2009-June/054428.html,
Michele De Candia posted a patch to not count bad blocks toward the
requested size to be erased.  This is desireable when you're passing in
something like $filesize, but not when you're trying to erase a partition.

Thus, a .spread subcommand (named for consistency with
http://lists.denx.de/pipermail/u-boot/2010-August/075163.html) is introduced
to make explicit the user's desire to erase for a given amount of data,
rather than to erase a specific region of the chip.

While passing $filesize to "nand erase" is useful, accidentally passing
something like $fliesize currently produces quite unpleasant results, as the
variable evaluates to nothing and U-Boot assumes that you want to erase
the entire rest of the chip/partition.  To improve the safety of the
erase command, require the user to make explicit their intentions by
using a .part or .chip subcommand.  This is an incompatible user interface
change, but keeping compatibility would eliminate the safety gain, and IMHO
it's worth it.

While touching nand_erase_opts(), make it accept 64-bit offsets and sizes,
fix the percentage display when erase length is rounded up, eliminate
an inconsistent warning about rounding up the erase length which only
happened when the length was less than one block (rounding up for $filesize
is normal operation), and add a diagnostic if there's an attempt to erase
beginning at a non-block boundary.

Signed-off-by: Scott Wood <scottwood@freescale.com>
Tested-by: Ben Gardiner <bengardiner@nanometrics.ca>
common/cmd_nand.c
drivers/mtd/nand/nand_util.c
include/nand.h