mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-25 11:04:28 -04:00 
			
		
		
		
	Memory leak is caused by the way hotplug2 handles environment variables, using setenv() and unsetenv(). setenv() creates copies of the supplied strings, but, due to a POSIX blunder, these copies are never destroyed by unsetenv(), neither in glibc nor uclibc - not until the program terminates. Since some events are handled directly in the main process, even when configured with the "fork" worker, hotplug2 memory usage will keep growing over time. This can be observed by running "udevtrigger" and noting the increase in hotplug2 VmRSS after each run. This patch uses putenv() instead, which leaves storage management to the caller, so that we can explicitly delete stuff when it's no longer needed. Signed-off-by: Aleksandar Radovanovic <biblbroks@sezampro.rs> SVN-Revision: 18725
		
			
				
	
	
		
			23 lines
		
	
	
		
			503 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			23 lines
		
	
	
		
			503 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
| diff -Naur a/common.mak b/common.mak
 | |
| --- a/common.mak	2009-11-18 13:15:21.000000000 +0000
 | |
| +++ b/common.mak	2009-11-18 13:25:18.000000000 +0000
 | |
| @@ -1,7 +1,7 @@
 | |
|  # vim:set sw=8 nosta:
 | |
|  
 | |
|  COPTS=-Os -Wall -g
 | |
| -LDFLAGS=-g -ldl
 | |
| +LDFLAGS=-g
 | |
|  
 | |
|  CFLAGS=$(COPTS)
 | |
|  FPIC=-fPIC
 | |
| diff -Naur a/Makefile b/Makefile
 | |
| --- a/Makefile	2009-11-18 13:15:21.000000000 +0000
 | |
| +++ b/Makefile	2009-11-18 13:25:18.000000000 +0000
 | |
| @@ -40,5 +40,6 @@
 | |
|    CFLAGS += -DSTATIC_WORKER=1
 | |
|  else
 | |
|    CFLAGS += $(FPIC)
 | |
| +  LDFLAGS += -ldl
 | |
|  endif
 | |
|  
 |