diff options
author | Yaniv Levinsky <yaniv.levinsky@compulab.co.il> | 2018-06-24 19:16:57 +0300 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2018-07-19 16:17:58 -0400 |
commit | c5d548a9f881b2268f1d81dab9cd329ae336607e (patch) | |
tree | 5a0e567d718a3d1816ab6ce8145be83067bca46b /env/mmc.c | |
parent | 5a04264ecf5f0f853f2d562b4c5efb139d3d4a9d (diff) | |
download | u-boot-c5d548a9f881b2268f1d81dab9cd329ae336607e.tar.gz u-boot-c5d548a9f881b2268f1d81dab9cd329ae336607e.tar.bz2 u-boot-c5d548a9f881b2268f1d81dab9cd329ae336607e.zip |
env: common: accept flags on reset to default env
The function set_default_env() sets the hashtable flags for import_r().
Formally set_default_env() doesn't accept flags from its callers. In
practice the caller can (un)set the H_INTERACTIVE flag, but it has to be
done using the first character of the function's string argument. Other
flags like H_FORCE can't be set by the caller.
Change the function to accept flags argument. The benefits are:
1. The caller will have to explicitly set the H_INTERACTIVE flag,
instead of un-setting it using a special char in a string.
2. Add the ability to propagate flags from the caller to himport(),
especially the H_FORCE flag from do_env_default() in nvedit.c that
currently gets ignored for "env default -a -f" commands.
3. Flags and messages will not be coupled together. A caller will be
able to set flags without passing a string and vice versa.
Please note:
The propagation of H_FORCE from do_env_default() does not introduce any
functional changes, because currently himport_r() is set to destroy the
old environment regardless if H_FORCE flag is set or not. More changes
are needed to utilize the propagation of H_FORCE.
Signed-off-by: Yaniv Levinsky <yaniv.levinsky@compulab.co.il>
Acked-by: Igor Grinberg <grinberg@compulab.co.il>
Diffstat (limited to 'env/mmc.c')
-rw-r--r-- | env/mmc.c | 12 |
1 files changed, 6 insertions, 6 deletions
@@ -155,19 +155,19 @@ static inline int mmc_set_env_part(struct mmc *mmc) {return 0; }; static const char *init_mmc_for_env(struct mmc *mmc) { if (!mmc) - return "!No MMC card found"; + return "No MMC card found"; #if CONFIG_IS_ENABLED(BLK) struct udevice *dev; if (blk_get_from_parent(mmc->dev, &dev)) - return "!No block device"; + return "No block device"; #else if (mmc_init(mmc)) - return "!MMC init failed"; + return "MMC init failed"; #endif if (mmc_set_env_part(mmc)) - return "!MMC partition switch failed"; + return "MMC partition switch failed"; return NULL; } @@ -298,7 +298,7 @@ fini: fini_mmc_for_env(mmc); err: if (ret) - set_default_env(errmsg); + set_default_env(errmsg, 0); #endif return ret; @@ -339,7 +339,7 @@ fini: fini_mmc_for_env(mmc); err: if (ret) - set_default_env(errmsg); + set_default_env(errmsg, 0); #endif return ret; } |