mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-10-31 12:08:19 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			237 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			237 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * (C) Copyright 2003
 | |
|  * Murray Jensen, CSIRO-MIT, <Murray.Jensen@csiro.au>
 | |
|  *
 | |
|  * See file CREDITS for list of people who contributed to this
 | |
|  * project.
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU General Public License as
 | |
|  * published by the Free Software Foundation; either version 2 of
 | |
|  * the License, or (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program; if not, write to the Free Software
 | |
|  * Foundation, Inc., 59 Temple Place, Suite 330, Boston,
 | |
|  * MA 02111-1307 USA
 | |
|  */
 | |
| 
 | |
| #include <common.h>
 | |
| 
 | |
| DECLARE_GLOBAL_DATA_PTR;
 | |
| 
 | |
| /* imports from fetch.c */
 | |
| extern int fetch_and_parse (char *, ulong, int (*)(uchar *, uchar *));
 | |
| 
 | |
| /* this is relative to the root of the server's tftp directory */
 | |
| static char *def_global_env_path = "/hymod/global_env";
 | |
| 
 | |
| static int
 | |
| env_callback (uchar *name, uchar *value)
 | |
| {
 | |
| 	hymod_conf_t *cp = &gd->bd->bi_hymod_conf;
 | |
| 	char ov[CFG_CBSIZE], nv[CFG_CBSIZE], *p, *q, *nn, c, *curver, *newver;
 | |
| 	int override = 1, append = 0, remove = 0, nnl, ovl, nvl;
 | |
| 
 | |
| 	nn = (char *)name;
 | |
| 
 | |
| 	if (*nn == '-') {
 | |
| 		override = 0;
 | |
| 		nn++;
 | |
| 	}
 | |
| 
 | |
| 	while (*nn == ' ' || *nn == '\t')
 | |
| 		nn++;
 | |
| 
 | |
| 	if ((nnl = strlen (nn)) == 0) {
 | |
| 		printf ("Empty name in global env file\n");
 | |
| 		return (0);
 | |
| 	}
 | |
| 
 | |
| 	if ((c = nn[nnl - 1]) == '+' || c == '-') {
 | |
| 		if (c == '+')
 | |
| 			append = 1;
 | |
| 		else
 | |
| 			remove = 1;
 | |
| 		nn[--nnl] = '\0';
 | |
| 	}
 | |
| 
 | |
| 	while (nnl > 0 && ((c = nn[nnl - 1]) == ' ' || c == '\t'))
 | |
| 		nn[--nnl] = '\0';
 | |
| 	if (nnl == 0) {
 | |
| 		printf ("Empty name in global env file\n");
 | |
| 		return (0);
 | |
| 	}
 | |
| 
 | |
| 	p = (char *)value;
 | |
| 	q = nv;
 | |
| 
 | |
| 	while ((c = *p) == ' ' || c == '\t')
 | |
| 		p++;
 | |
| 
 | |
| 	nvl = strlen (p);
 | |
| 	while (nvl > 0 && ((c = p[nvl - 1]) == ' ' || c == '\t'))
 | |
| 		p[--nvl] = '\0';
 | |
| 
 | |
| 	while ((*q = *p++) != '\0') {
 | |
| 		if (*q == '%') {
 | |
| 			switch (*p++) {
 | |
| 
 | |
| 			case '\0':	/* whoops - back up */
 | |
| 				p--;
 | |
| 				break;
 | |
| 
 | |
| 			case '%':	/* a single percent character */
 | |
| 				q++;
 | |
| 				break;
 | |
| 
 | |
| 			case 's':	/* main board serial number as string */
 | |
| 				q += sprintf (q, "%010lu",
 | |
| 					cp->main.eeprom.serno);
 | |
| 				break;
 | |
| 
 | |
| 			case 'S':	/* main board serial number as number */
 | |
| 				q += sprintf (q, "%lu", cp->main.eeprom.serno);
 | |
| 				break;
 | |
| 
 | |
| 			default:	/* ignore any others */
 | |
| 				break;
 | |
| 			}
 | |
| 		}
 | |
| 		else
 | |
| 			q++;
 | |
| 	}
 | |
| 
 | |
| 	if ((nvl = q - nv) == 0) {
 | |
| 		setenv (nn, NULL);
 | |
| 		return (1);
 | |
| 	}
 | |
| 
 | |
| 	if ((curver = getenv ("global_env_version")) == NULL)
 | |
| 		curver = "unknown";
 | |
| 
 | |
| 	if ((newver = getenv ("new_genv_version")) == NULL || \
 | |
| 	    strcmp (curver, newver) == 0) {
 | |
| 		if (strcmp (nn, "version") == 0)
 | |
| 			setenv ("new_genv_version", nv);
 | |
| 		return (1);
 | |
| 	}
 | |
| 
 | |
| 	if ((p = getenv (nn)) != NULL) {
 | |
| 
 | |
| 		strcpy (ov, p);
 | |
| 		ovl = strlen (ov);
 | |
| 
 | |
| 		if (append) {
 | |
| 
 | |
| 			if (strstr (ov, nv) == NULL) {
 | |
| 
 | |
| 				printf ("Appending '%s' to env var '%s'\n",
 | |
| 					nv, nn);
 | |
| 
 | |
| 				while (nvl >= 0) {
 | |
| 					nv[ovl + 1 + nvl] = nv[nvl];
 | |
| 					nvl--;
 | |
| 				}
 | |
| 
 | |
| 				nv[ovl] = ' ';
 | |
| 
 | |
| 				while (--ovl >= 0)
 | |
| 					nv[ovl] = ov[ovl];
 | |
| 
 | |
| 				setenv (nn, nv);
 | |
| 			}
 | |
| 
 | |
| 			return (1);
 | |
| 		}
 | |
| 
 | |
| 		if (remove) {
 | |
| 
 | |
| 			if (strstr (ov, nv) != NULL) {
 | |
| 
 | |
| 				printf ("Removing '%s' from env var '%s'\n",
 | |
| 					nv, nn);
 | |
| 
 | |
| 				while ((p = strstr (ov, nv)) != NULL) {
 | |
| 					q = p + nvl;
 | |
| 					if (*q == ' ')
 | |
| 						q++;
 | |
| 					strcpy(p, q);
 | |
| 				}
 | |
| 
 | |
| 				setenv (nn, ov);
 | |
| 			}
 | |
| 
 | |
| 			return (1);
 | |
| 		}
 | |
| 
 | |
| 		if (!override || strcmp (ov, nv) == 0)
 | |
| 			return (1);
 | |
| 
 | |
| 		printf ("Re-setting env cmd '%s' from '%s' to '%s'\n",
 | |
| 			nn, ov, nv);
 | |
| 	}
 | |
| 	else
 | |
| 		printf ("Setting env cmd '%s' to '%s'\n", nn, nv);
 | |
| 
 | |
| 	setenv (nn, nv);
 | |
| 	return (1);
 | |
| }
 | |
| 
 | |
| void
 | |
| hymod_check_env (void)
 | |
| {
 | |
| 	char *p, *path, *curver, *newver;
 | |
| 	int firsttime = 0, needsave = 0;
 | |
| 
 | |
| 	if (getenv ("global_env_loaded") == NULL) {
 | |
| 		puts ("*** global environment has never been loaded\n");
 | |
| 		puts ("*** fetching from server");
 | |
| 		firsttime = 1;
 | |
| 	}
 | |
| 	else if ((p = getenv ("always_check_env")) != NULL &&
 | |
| 	    strcmp (p, "yes") == 0)
 | |
| 		puts ("*** checking for updated global environment");
 | |
| 	else
 | |
| 		return;
 | |
| 
 | |
| 	puts (" (Control-C to Abort)\n");
 | |
| 
 | |
| 	if ((path = getenv ("global_env_path")) == NULL || *path == '\0')
 | |
| 		path = def_global_env_path;
 | |
| 
 | |
| 	if (fetch_and_parse (path, CFG_LOAD_ADDR, env_callback) == 0) {
 | |
| 		puts ("*** Fetch of global environment failed!\n");
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	if ((newver = getenv ("new_genv_version")) == NULL) {
 | |
| 		puts ("*** Version number not set - contents ignored!\n");
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	if ((curver = getenv ("global_env_version")) == NULL || \
 | |
| 	    strcmp (curver, newver) != 0) {
 | |
| 		setenv ("global_env_version", newver);
 | |
| 		needsave = 1;
 | |
| 	}
 | |
| 	else
 | |
| 		printf ("*** Global environment up-to-date (ver %s)\n", curver);
 | |
| 
 | |
| 	setenv ("new_genv_version", NULL);
 | |
| 
 | |
| 	if (firsttime) {
 | |
| 		setenv ("global_env_loaded", "yes");
 | |
| 		needsave = 1;
 | |
| 	}
 | |
| 
 | |
| 	if (needsave)
 | |
| 		puts ("\n*** Remember to run the 'saveenv' "
 | |
| 			"command to save the changes\n\n");
 | |
| }
 |