On Wed, Jun 26, 2019 at 12:29 PM Frank Wunderlich <fran...@public-files.de> wrote: > > this adds erase environment for mmc storage > > squashed fixes: > - add CONFIG_CMD_ERASEENV > - env: erase redundant offset if defined > > Suggested-by: Simon Goldschmidt <simon.k.r.goldschm...@gmail.com> > Signed-off-by: Frank Wunderlich <fran...@public-files.de> > --- > env/mmc.c | 52 ++++++++++++++++++++++++++++++++++++++++++++++++++++ > 1 file changed, 52 insertions(+) > > diff --git a/env/mmc.c b/env/mmc.c > index c3cf35d01b..da5cf21637 100644 > --- a/env/mmc.c > +++ b/env/mmc.c > @@ -242,6 +242,55 @@ fini: > fini_mmc_for_env(mmc); > return ret; > } > + > +#if defined(CONFIG_CMD_ERASEENV)
Seems you missed the CONFIG_SPL_BUILD guard here? > +static inline int erase_env(struct mmc *mmc, unsigned long size, > + unsigned long offset) > +{ > + uint blk_start, blk_cnt, n; > + struct blk_desc *desc = mmc_get_blk_desc(mmc); > + > + blk_start = ALIGN(offset, mmc->write_bl_len) / > mmc->write_bl_len; > + blk_cnt = ALIGN(size, mmc->write_bl_len) / mmc->write_bl_len; > + > + n = blk_derase(desc, blk_start, blk_cnt); > + printf("%d blocks erased: %s\n", n, (n == blk_cnt) ? "OK" : "ERROR"); > + > + return (n == blk_cnt) ? CMD_RET_SUCCESS : CMD_RET_FAILURE; This is no command, don't use the CMD_RET_ macros. > +} > + > +static int env_mmc_erase(void) > +{ > + int dev = mmc_get_env_dev(); > + struct mmc *mmc = find_mmc_device(dev); > + int ret, copy = 0; > + u32 offset; > + > + if (!mmc) > + return CMD_RET_FAILURE; > + > + if (mmc_getwp(mmc) == 1) { Why is this needed when save doesn't use it? > + printf("Error: card is write protected!\n"); > + return CMD_RET_FAILURE; > + } Is 'init_mmc_for_env' not needed here? Regards, Simon > + > + if (mmc_get_env_addr(mmc, copy, &offset)) > + return CMD_RET_FAILURE; > + > + ret = erase_env(mmc, CONFIG_ENV_SIZE, offset); > + > +#ifdef CONFIG_ENV_OFFSET_REDUND > + copy = 1; > + > + if (mmc_get_env_addr(mmc, copy, &offset)) > + return CMD_RET_FAILURE; > + > + ret |= erase_env(mmc, CONFIG_ENV_SIZE, offset); > +#endif > + > + return ret; > +} > +#endif /* CONFIG_CMD_ERASEENV */ > #endif /* CONFIG_CMD_SAVEENV && !CONFIG_SPL_BUILD */ > > static inline int read_env(struct mmc *mmc, unsigned long size, > @@ -351,5 +400,8 @@ U_BOOT_ENV_LOCATION(mmc) = { > .load = env_mmc_load, > #ifndef CONFIG_SPL_BUILD > .save = env_save_ptr(env_mmc_save), > +#if defined(CONFIG_CMD_ERASEENV) > + .erase = env_mmc_erase, > +#endif > #endif > }; > -- > 2.17.1 > _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de https://lists.denx.de/listinfo/u-boot