[U-Boot] [PATCHv1 02/22] arm: socfpga: enable saveenv to mmc partition
Pavel Machek
pavel at denx.de
Fri Jan 16 19:35:11 CET 2015
Hi!
> > > -#define CONFIG_ENV_IS_NOWHERE
> > >
> > > #define CONFIG_ENV_SIZE 4096
> > >
> > > +#define CONFIG_ENV_IS_IN_MMC
> > > +#define CONFIG_SYS_MMC_ENV_DEV 0/* device 0 */
> > > +#define CONFIG_ENV_OFFSET 512/* just after the MBR */
> > > +
> >
> > Would it make sense to make environment bigger (64K?) at this point,
> > and enabling the redundant environment option, so that one bad block
> > does not bring the whole device down?
>
> Do you think you'll ever have more than a 4KiB of text data in the env ?
> I can see a reason for some 16 KiB environment, but that's the
> ceiling.
We have hit 4KiB size already, and I believe we are over 8KiB,
even. wagabuibui loads a lot of small files from flash.
So if 16KiB is acceptable, lets do that.
> Usually, the env only has to be a few KiB and it's size has to be multiple
> of the underlying device's erase block. But in case of SD card, there are no
> explicit erase blocks exported to the user, all is hidden by the controller
> in the SD card and gives an illusion of a device which has 512b
> blocks and
Allocation unit is usually 2, 4, 6, 8, 12 or 16 MiB on recent flash
cards. It is field in uSD card structure somewhere. We could choose
24MiB, to have GCD, but... see:
https://wiki.linaro.org/WorkingGroups/KernelArchived/Projects/FlashCardSurvey
> the user doesn't care for bad block management. Since the controller in the
> card does the bad block management and wear leveling/relocation of blocks,
> it also means that in case the controller did fail to provide the block which
> contains env, the whole card would already be in a very bad state.
Bad block management means you don't get errors during write, but you
can still get errors during read.
Pavel
--
(english) http://www.livejournal.com/~pavelmachek
(cesky, pictures) http://atrey.karlin.mff.cuni.cz/~pavel/picture/horses/blog.html
More information about the U-Boot
mailing list