|
|
cURL Mailing List Monthly Index Single Mail
curl-tracker mailing list Archives
[ curl-Bugs-1229810 ] Memory leak in curl_easy_perform method
From: SourceForge.net <noreply_at_sourceforge.net>
Date: Tue, 17 Oct 2006 04:52:18 -0700
Bugs item #1229810, was opened at 2005-06-29 18:18
Please note that this message will contain a full copy of the comment thread,
Initial Comment:
I am currently using the libcurl library to perform file
I have found memory leaks while using the
I attach the report summary generated by Insure tool.
On the other hand, I indicate the libcurl version (curl -V) I
************************ curl -V ********************************
Could anybody tell me if this bug is fixed in the latest
Thanks in advance for all your support.
Julio Garvía
----------------------------------------------------------------------
Comment By: Sven Wegener (mister-x)
Message:
Hi!
I stumbled across this bug myself, please read on:
The DNS cache is written as a linked list and stores the
Best solution is to assign a free function to the list, that
Sven
-- Sven Wegener Gentoo Developer http://www.gentoo.org/ ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-08-04 10:01 Message: Logged In: YES user_id=1110 Thanks for your report, your details and your hard work. I hope you'll work it out, and don't hesitate to get in touch again if you suspect problems in libcurl. ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-08-04 10:00 Message: Logged In: YES user_id=1304874 According to your comments I think the subject is also closed on my behalf (so the status of this bug can be switched to 'closed', does it?). I will investigate if the problem is in 'libc' or even though in 'insure'. Anyways, it has been a pleasure to work with you and needless to say that if you need any kind of help that I could give you, you only have to contact me at: jgarvia_at_mixmail.com Thanks a lot for all your work. Best wishes, Julio Garvía. ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-08-03 20:18 Message: Logged In: YES user_id=1110 I know you've reported ps uax outputs. But you did this in the curl/libcurl bug tracker and I've only researched this topic in the aspect of possible bugs in libcurl. I therefore don't care about leaks or problems elsewhere. Hence I use tools and ways to verify that libcurl works fine. When it does, I'm happy and the subject is closed on my behalf. That may not suit you, but that is as far as my effort goes. I would suggest that your libc version has a memory leak or that insure is wrong. Such things have happened before. But as far as this bug tracker and libcurl goes, this is not a bug. ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-08-01 14:38 Message: Logged In: YES user_id=1304874 As I mentioned in previous messages, the key to alert us about memory leaks was motivated by the `ps axu' reports. That is, after running the command line process (in UNIX) during three days (in indefinite mode and continuously trasnferring files), I noticed that the memory increases without stopping. However, I ran the same scenario in Linux and no memory increasing was reported. Moreover, running the process in UNIX and compiling with Insure, the following line is pointed for leaving memory leaks at exit: #File: hostip6.c error = getaddrinfo(hostname, sbuf, &hints, &res); Additionally, Insure also points the following line as 'Outstanding allocated memory': #File: inet_ntop.c ptr = inet_ntoa_r(*(struct in_addr*)src, dst); No more reports are generated by Insure. By that way, I cannot assure that there were a memory leak, but ... Is it normal such memory consumption? (I do not know) Julio Garvía ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-08-01 13:46 Message: Logged In: YES user_id=1110 Thanks for your work on making test programs! I made it iterate three times with a full source dir each time, thus uploading 600 files. I didn't detect any leak in libcurl (using the built-in libcurl memory debug tool). I then re-ran it with valgrind with the same three iterations, and it too found no memory leaks at all. So, whatever you see I can't see that libcurl is to blame for any memory leak. ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-08-01 12:14 Message: Logged In: YES user_id=1304874 O.K. I have attached a new *.c version to allow executing a limited number of scanning iterations. If you use '-i' command line option, you could specify the maximum number of scanning iterations (if you do not specify it, then indefinite iterations will be taken by default) PS: You can terminate the program (in a controlled way) by sending TERM or INT signals. Regards, Julio Garvía ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-07-30 23:46 Message: Logged In: YES user_id=1110 Can't you make the example run for a limited number of rounds and then exit? If it leaks, it would make it "easy" to figure out and detect the leaks then. A never-ending program is a lot harder. ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-07-28 10:55 Message: Logged In: YES user_id=1304874 Hello, After a long time, I am here again with the memory leak issue (first of all, sorry for the delay). Well, I have prepared another command line program to perform FTPs continuosly. It scans (in an infinite loop) in a given directory looking for files to be transferred (once the FTP is done, the file is remove from the source path). (Please, execute MyFtp to see the command line options). If you execute this process (in UNIX) you will see how 'ps axu' reports that memory is increasing. I have check it with the following scenario: 1. Starts MyFtp process as follows: MyFtp -h <Host> -l <User> -p <Pwd> -s/usr/users/jgarvia/MyFtp/FtpSource -t/usr/users/jgarvia/MyFtp/FtpTarget -c 60 2. Inserts entries to be trasnferred in the source path. I have put 200 entries every 2 minutes via 'PutFiles.sh' script. 3. Checks the memory reports with 'ps axu'. I have done it with 'MemoryLog.sh' script. PS: I have run MyFtp process during two days. PS: Affected files are attached in MyFtp_01.tar.gz Hopefully, it could help us to determine if there is a memory leak or not. With best regards, Julio Garvía ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-07-06 15:05 Message: Logged In: YES user_id=1304874 Certainly, the points mentioned by valgrind are not reported as memory leaks but as 'something strange'. Anyways, I continue trying to know why the memory is increasing. ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-07-06 15:05 Message: Logged In: YES user_id=1304874 Certainly, the points mentioned by valgrind are not reported as memory leaks but as 'something strange'. Anyways, I continue trying to know why the memory is increasing. ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-07-06 12:12 Message: Logged In: YES user_id=1304874 Certainly, the points mentioned by valgrind are not reported as memory leaks but as 'something strange'. Anyways, I continue trying to know why the memory is increasing. ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-07-06 12:01 Message: Logged In: YES user_id=1110 Your program never ends so whenever it is stopped of course there are still some allocated resources. If you make it loop only N laps, does it still show those leaks? I certainly couldn't see any. But feel free to prove me wrong! ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-07-06 11:45 Message: Logged In: YES user_id=1304874 Just one appointment: Executing the program I attached (in Linux) using 'valgrind' with '--v' and '--leak-check=yes' options, some information is reported about the same points reported by Insure report. ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-07-06 11:38 Message: Logged In: YES user_id=1304874 Just one appointment: Executing the program I attached (in Linux) using 'valgrind' with '--v' and '--leak-check=yes' options, some information is reported about the same points reported by Insure report. ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-07-06 00:24 Message: Logged In: YES user_id=1110 Yes it certainly sounds like a leak. I just can't see where/why libcurl would leak it. I'm puzzled why your insure tool reports a leak when my tests don't leak at that point... ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-07-05 16:40 Message: Logged In: YES user_id=1304874 Not so far, but 'ps axu' is telling that memory is increasing ... I will continue investigating. Hopefully, no leaks, but... Why is the memory increasing when calling curl_easy_perform()? (I do not know so far) ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-07-05 16:03 Message: Logged In: YES user_id=1110 Any news? ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-07-01 13:54 Message: Logged In: YES user_id=1110 Ok, I modified the while(1) to become a counter=10; while(counter--) instead and ran it on my linux box (using getaddrinfo). Not a single byte leaks... ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-07-01 11:57 Message: Logged In: YES user_id=1304874 Hi again, I have prepared an example for uploading the same file in an infinite loop to see how the memory is increasing. You could just modify the Makefile (LIBCURLDIR and INCCURLDIR) and just call 'make' to compile. Then type 'MyFtp' and the usage will be shown. When you execute 'MyFtp' application the same file wil be uploaded to the same location indefinitely (until termination signal). Then if you execute periodically a 'ps' (I have also attach a script: 'Log_Memoria_00.sh >> LogMemoryLeaks.log &'), you will see how the memory is increasing a lot. That is what made me suspect that there is a memory leak (and the Insure report provides us some clues), but probably the application requires a huge memory to perform its activity (I do not know). In any case, I am currently executing the process and it will not stop until the next Monday (three days running) in order to see if the memory do not stop of increasing (in that case, I guess a memory leak could be there, otherwise all could be OK). Best regards, Julio Garvía ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-06-30 17:47 Message: Logged In: YES user_id=1110 but I should mention that I don't think any fixes related to this problem have been made since the 7.14.0 release, so I expect you get the same reports on the latest CVS sources as well ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-06-30 17:37 Message: Logged In: YES user_id=1110 Daily snapshots: (and my recent tru64-related memdebug things will be included in tomorrow's snapshot) http://cool.haxx.se/curl-daily/ How to get it off CVS: http://curl.haxx.se/cvs.html ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-06-30 17:31 Message: Logged In: YES user_id=1304874 O.K. I will do what you said, but, Could you tell me where can I get the new sources? Hopefully we wil solve this "trouble" soon :-) ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-06-30 16:15 Message: Logged In: YES user_id=1110 built just now: $ ./src/curl -V curl 7.14.1-CVS (alphaev67-dec-osf5.1) libcurl/7.14.1-CVS Protocols: ftp gopher telnet dict ldap http file Features: Debug IPv6 Largefile This is curl on tru64, with --enable-debug (I've just made it possible). It shows _no_ leak at all. When getting a file over FTP, I see two calls to getaddrinfo() and I see two calls to freeaddrinfo(). I guess now is the time where you show me exactly what you do to see this leak! ;-) ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-06-30 15:06 Message: Logged In: YES user_id=1110 libcurl features a DNS cache where all successful name resolves are kept, so they are not freed immediately after use. The call to Curl_cache_addr() adds the resolved data to the cache. If the entry remains in the cache until the handle is closed, it gets freed from Curl_close() when Curl_hash_destroy() is called. ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-06-30 14:52 Message: Logged In: YES user_id=1304874 Yes, I call 'curl_easy_cleanup()' as well as 'curl_global_cleanup()'. Well, let me show where I guess there is a memory leak (according to insure report). As you could see in the source code: In hostip6.c (line 257) the getaddrinfo function allocates memory for its fourth parameter and it is returned. In hostip.c (line 423) the previously returned value is used (and stored in a local variable - 'addr'), but only released when 'dns' variable is NULL. Then my question is, Why the 'addr' relasing depends on another variable? I guess the releasing should be performed as below: if(addr) { Curl_freeaddrinfo(addr); } The memory leak seems to be provoked because 'addr' is not always released, due to its releasing depends on another variable different from 'addr'. Ciao, Julio Garvía ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-06-30 13:53 Message: Logged In: YES user_id=1110 Did you really call curl_easy_cleanup() too? ---------------------------------------------------------------------- Comment By: jgarvia (jgarvia) Date: 2005-06-30 11:52 Message: Logged In: YES user_id=1304874 I have just installed the new library version and the same memory leaks are still there. Regarding the Insure report, I attach the new one. The way to analyze it, is from down to top (for every reported chunk). BTW, the first line of every reported chunk indicates the function, file and line in which the memory is allocated (the rest of the lines indicate the points that calls or use the memory allocated by that first function). So, analyzing the second reported chunk (in the latest Insure report) if you go to file 'hostip6.c', function 'Curl_getaddrinfo()' and line '257' you could see how the leaked memory is allocated (but never released in file 'ftp.c', function 'Curl_perform()' and line '2146'). (This particular leak is about the fourth parameter of 'getaddrinfo' function that is returned by 'Curl_getaddrinfo()', but never released) Please, if you still need an example, tell me and I will prepare it for you. Thanks. Julio Garvía ---------------------------------------------------------------------- Comment By: Daniel Stenberg (bagder) Date: 2005-06-29 19:46 Message: Logged In: YES user_id=1110 First, I must admit I don't understand the report. What source/line does it say allocated the memory that was leaked? How much memory was it? Can't you simply build 7.14.0 and test to see if the leak is still present or not? Can you show us an example program (that leaks this memory) that we can use to repeat this problem? ---------------------------------------------------------------------- You can respond by visiting: https://sourceforge.net/tracker/?func=detail&atid=100976&aid=1229810&group_id=976Received on 2006-10-17 These mail archives are generated by hypermail. |
Page updated November 12, 2010.
web site info