public inbox for u-boot@lists.denx.de
 help / color / mirror / Atom feed
* [U-Boot] unassigned-patches/34: [PATCH] Add support for setting environment variable from RAM.
       [not found] <1233611420-21083-1-git-send-email-eric.nelson@boundarydevices.com>
@ 2009-02-05 16:20 ` u-boot at bugs.denx.de
  2009-02-05 16:21   ` Eric Nelson
  0 siblings, 1 reply; 2+ messages in thread
From: u-boot at bugs.denx.de @ 2009-02-05 16:20 UTC (permalink / raw)
  To: u-boot

This is useful for allowing scripts to read environment variables from
file, among other things.

This is a slightly modified version of what Alessandro submitted to the
mailing list last July:
	http://www.mail-archive.com/u-boot-users at lists.sourceforge.net/msg07932.html

I changed the name from 'setenvram' to 'ramenv' to prevent breakage of scripts
that use the abbreviation 'set' (which my handss have the habit of doing).

Signed-off-by: Eric Nelson <eric.nelson@boundarydevices.com>

---
Added to GNATS database as unassigned-patches/34
>Responsible:    patch-coord
>Message-Id:     <1233611420-21083-1-git-send-email-eric.nelson@boundarydevices.com>
>In-Reply-To:    
>References:     
>Patch-Date:     Mon Feb 02 22:50:20 +0100 2009
---
 common/cmd_nvedit.c |   46 ++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 46 insertions(+), 0 deletions(-)

diff --git a/common/cmd_nvedit.c b/common/cmd_nvedit.c
index 1fcb4c9..bcb6d9f 100644
--- a/common/cmd_nvedit.c
+++ b/common/cmd_nvedit.c
@@ -494,6 +494,44 @@ int do_askenv ( cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
 #endif
 
 /************************************************************************
+ * Set a new environment variable from RAM.
+ * Requires three arguments: the variable name, a memory address and a length.
+ *
+ * Deletes the environment variable if the length is zero.
+ */
+int do_ramenv(cmd_tbl_t *cmdtp, int flag, int argc, char *argv[])
+{
+	unsigned long len, i;
+	char *addr;
+
+	if (argc != 4) {
+		cmd_usage(cmdtp);
+		return 1;
+	}
+	addr = (char *)simple_strtol(argv[2], NULL, 16);
+	len = simple_strtol(argv[3], NULL, 16);
+	if (!addr || !len) {
+		cmd_usage(cmdtp);
+		return 1;
+	}
+	addr[len] = '\0';
+	for (i = 0; i < len; i++) {
+		/* turn newlines into semicolon */
+		if (addr[i] == '\n')
+			addr[i] = ';'; /* ignore dos-style newlines */
+		if (addr[i] == '\r')
+			addr[i] = ' '; /* accept sh-comments and discard them */
+		if (addr[i] == '#') {
+			while (addr[i] && addr[i] != '\n')
+				addr[i++] = ' ';
+			i--;
+		}
+	}
+	setenv(argv[1], addr);
+	return 0;
+}
+
+/************************************************************************
  * Look up variable from environment,
  * return address of storage for that variable,
  * or NULL if not found
@@ -605,6 +643,14 @@ U_BOOT_CMD(
 	"    - delete environment variable 'name'\n"
 );
 
+U_BOOT_CMD(
+	ramenv, 4, 0, do_ramenv,
+	"ramenv  - get environment variable from ram\n",
+	"name addr maxlen\n"
+	"    - set environment variable 'name' from addr 'addr'\n"
+	"    - delete environment variable if maxlen is 0\n"
+);
+
 #if defined(CONFIG_CMD_ASKENV)
 
 U_BOOT_CMD(
-- 
1.5.5.1.382.g182fb

^ permalink raw reply related	[flat|nested] 2+ messages in thread

* [U-Boot] unassigned-patches/34: [PATCH] Add support for setting environment variable from RAM.
  2009-02-05 16:20 ` [U-Boot] unassigned-patches/34: [PATCH] Add support for setting environment variable from RAM u-boot at bugs.denx.de
@ 2009-02-05 16:21   ` Eric Nelson
  0 siblings, 0 replies; 2+ messages in thread
From: Eric Nelson @ 2009-02-05 16:21 UTC (permalink / raw)
  To: u-boot

u-boot at bugs.denx.de wrote:
> This is useful for allowing scripts to read environment variables from
> file, among other things.
> 
Please disregard. This was covered on the U-Boot users list.

^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2009-02-05 16:21 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
     [not found] <1233611420-21083-1-git-send-email-eric.nelson@boundarydevices.com>
2009-02-05 16:20 ` [U-Boot] unassigned-patches/34: [PATCH] Add support for setting environment variable from RAM u-boot at bugs.denx.de
2009-02-05 16:21   ` Eric Nelson

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox