svn commit: r211158 - head/sys/dev/cfe
Neel Natu
neel at FreeBSD.org
Wed Aug 11 02:13:51 UTC 2010
Author: neel
Date: Wed Aug 11 02:13:50 2010
New Revision: 211158
URL: http://svn.freebsd.org/changeset/base/211158
Log:
Start using the 'init_static_kenv()' API provided by r198561 to initialize
CFE environment variables.
Modified:
head/sys/dev/cfe/cfe_env.c
Modified: head/sys/dev/cfe/cfe_env.c
==============================================================================
--- head/sys/dev/cfe/cfe_env.c Wed Aug 11 00:51:50 2010 (r211157)
+++ head/sys/dev/cfe/cfe_env.c Wed Aug 11 02:13:50 2010 (r211158)
@@ -25,8 +25,7 @@
*/
#include <sys/param.h>
-#include <sys/kernel.h>
-#include <sys/systm.h>
+#include <sys/kenv.h>
#include <dev/cfe/cfe_api.h>
@@ -43,32 +42,20 @@ static char cfe_env_buf[CFE_ENV_SIZE];
void
cfe_env_init(void)
{
- int idx, len;
- char name[64], val[128], *cp, *cplim;
+ int idx;
+ char name[KENV_MNAMELEN], val[KENV_MVALLEN];
- cp = cfe_env_buf;
- cplim = cp + CFE_ENV_SIZE;
+ init_static_kenv(cfe_env_buf, CFE_ENV_SIZE);
idx = 0;
while (1) {
if (cfe_enumenv(idx, name, sizeof(name), val, sizeof(val)) != 0)
break;
- if (bootverbose)
- printf("Importing CFE env: \"%s=%s\"\n", name, val);
-
- /*
- * name=val\0\0
- */
- len = strlen(name) + 1 + strlen(val) + 1 + 1;
- if (cplim - cp < len)
+ if (setenv(name, val) != 0) {
printf("No space to store CFE env: \"%s=%s\"\n",
name, val);
- else
- cp += sprintf(cp, "%s=%s", name, val) + 1;
+ }
++idx;
}
- *cp++ = '\0';
-
- kern_envp = cfe_env_buf;
}
More information about the svn-src-head
mailing list