setenv/unsetenv's known memory leak
    Seán C. Farley 
    sean-freebsd at farley.org
       
    Wed Feb 23 04:01:13 GMT 2005
    
    
  
While playing around with setenv(), I noticed that it can leak memory
when a program overwrites a variable with a larger value.  unsetenv()
will just leak memory.  All of this is documented in their man pages.
The latest PR on this (two PR's mentioned in it are closed):
http://www.freebsd.org/cgi/query-pr.cgi?pr=misc/19406
I could find no apparent reason for continuing to allow for the memory
leak.  The only reason given to allow it was to permit programs to
continue to use the environment variable retrieved by setenv() after the
program had reset or deleted it.
If a program can be assumed to have a persistent pointer, it should be
considered memory that should be freed by the program later.  Yes?
Obviously, this is not the case with the setenv()/unsetenv() API.  Also,
if the pointer is used by a program after it has been overwritten, the
program will be using the wrong value if the value was expanded in size.
After updating an environment variable, the value will be wrong (freed
memory or incorrect value) regardless if the leak is plugged or not.  It
stands to reason that fixing the leak should not be harmful.
In checking a different system, I verified that Linux does not exhibit
this leak.
Here is a test program along with a patch to stop the leak:
http://www.farley.org/freebsd/tmp/setenv.tar.bz2
Seán
-- 
sean-freebsd at farley.org
    
    
More information about the freebsd-hackers
mailing list