Update(__add_to_environ): Initialize ep after we have the lock.
authordrepper <drepper>
Thu, 19 Aug 1999 20:04:13 +0000 (20:04 +0000)
committerdrepper <drepper>
Thu, 19 Aug 1999 20:04:13 +0000 (20:04 +0000)
sysdeps/generic/setenv.c

index 387152d..29fc60c 100644 (file)
@@ -113,13 +113,17 @@ __add_to_environ (name, value, combined, replace)
      const char *combined;
      int replace;
 {
-  register char **ep = __environ;
+  register char **ep;
   register size_t size;
   const size_t namelen = strlen (name);
   const size_t vallen = value != NULL ? strlen (value) + 1 : 0;
 
   LOCK;
 
+  /* We have to get the pointer now that we have the lock and not earlier
+     since another thread might have created a new environment.  */
+  ep = __environ;
+
   size = 0;
   if (ep != NULL)
     {