diff options
| author | Gerlando Falauto <gerlando.falauto@keymile.com> | 2012-08-24 00:11:39 +0000 | 
|---|---|---|
| committer | Tom Rini <trini@ti.com> | 2012-09-18 12:01:52 -0700 | 
| commit | c5983592e912835fe9ed00b9d98b05580c460eae (patch) | |
| tree | 96245807698607969286b6b4d0b2f1b664fdb3e8 /common/cmd_nvedit.c | |
| parent | 348b1f1c6064990210a6797c86514fd358b73062 (diff) | |
| download | olio-uboot-2014.01-c5983592e912835fe9ed00b9d98b05580c460eae.tar.xz olio-uboot-2014.01-c5983592e912835fe9ed00b9d98b05580c460eae.zip | |
env: add check/apply logic to himport_r()
Change hashtable so that a callback function will decide whether a
variable can be overwritten, and possibly apply the changes.
So add a new field to struct hsearch_data:
 o "apply" callback function to check whether a variable can be
    overwritten, and possibly immediately apply the changes;
    when NULL, no check is performed.
And a new argument to himport_r():
 o "do_apply": whether to call the apply callback function
NOTE: This patch does not change the current behavior.
Signed-off-by: Gerlando Falauto <gerlando.falauto@keymile.com>
Reviewed-by: Marek Vasut <marex@denx.de>
Diffstat (limited to 'common/cmd_nvedit.c')
| -rw-r--r-- | common/cmd_nvedit.c | 3 | 
1 files changed, 2 insertions, 1 deletions
| diff --git a/common/cmd_nvedit.c b/common/cmd_nvedit.c index c601b3ac2..ddf3b8dfe 100644 --- a/common/cmd_nvedit.c +++ b/common/cmd_nvedit.c @@ -202,6 +202,7 @@ static int do_env_grep(cmd_tbl_t *cmdtp, int flag,   * environment variable, then (if successful) apply the changes to internals so   * to make them effective.  Code for this function was taken out of   * _do_env_set(), which now calls it instead. + * Also called as a callback function by himport_r().   * Returns 0 in case of success, 1 in case of failure.   * When (flag & H_FORCE) is set, do not print out any error message and force   * overwriting of write-once variables. @@ -915,7 +916,7 @@ static int do_env_import(cmd_tbl_t *cmdtp, int flag,  	}  	if (himport_r(&env_htab, addr, size, sep, del ? 0 : H_NOCLEAR, -			0, NULL) == 0) { +			0, NULL, 0 /* do_apply */) == 0) {  		error("Environment import failed: errno = %d\n", errno);  		return 1;  	} |