|
|
cURL Mailing List Monthly Index Single Mail
curl-tracker mailing list Archives
[ curl-Bugs-1604956 ] Memory leak if MAXCONNECTS == 0
From: SourceForge.net <noreply_at_sourceforge.net>
Date: Tue, 05 Dec 2006 07:37:37 -0800
Bugs item #1604956, was opened at 2006-11-29 02:36
Please note that this message will contain a full copy of the comment thread,
Initial Comment:
I've observed this using libcurl 7.16.0, and the line numbers I reference come from that release.
When MAXCONNECTS is set to 0, the connection cache doesn't have room to hold any connections. As a result, ConnectionStore(struct SessionHandle*, struct connectdata*), url.c:2170, will always fail to find room for a new connection and simply gives up. This isn't an immediate problem since a handle to the connection struct is held elsewhere.
When Curl_done(struct connectdata**, CURLCode), url.c:4033 is called at the end of the Curl_perform, it assumes that ConnectionStore managed to find a place to cache the connection and will leave it open for appropriate protocols like HTTP. Since there is no connection cache, this results in a memory leak.
The obvious workaround to this is to set FORBID_REUSE to 1, forcing the connections to be properly cleaned up.
It also looks like version 7.16 adds some support to better detect this (I originally found this in 7.14). connectdata.connectindex should be -1 if there was no space in the cache. I've only looked at the code for 7.16 very briefly, but if I'm following it correctly the patch to url.c should be:
4092c4092
--- > if(data->set.reuse_forbid || conn->bits.close) { I haven't been able to verify this yet (my environment is behaving a bit strangely right now). Maybe tomorrow. ---------------------------------------------------------------------- >Comment By: Daniel Stenberg (bagder) Date: 2006-12-05 16:37 Message: Logged In: YES user_id=1110 Originator: NO Thanks for your report and details. I've now committed a fix that prevents the SIGSEGV and I cannot see any memory leak, although now it will always use no less than 1 entry internally for the connection cache. ---------------------------------------------------------------------- Comment By: Jared Lundell (jaredlundell) Date: 2006-11-29 22:43 Message: Logged In: YES user_id=1656395 Originator: YES Well, it looks like I was mistaken in saying this exists in 7.16.0. When I thought I was testing with 7.16 it seems I was still using 7.14 instead. Rather than a memory leak I get a segfault whenever I try to set CURLOPT_MAXCONNECTS to any value at all. I've tried 0, 1 and 10, all of which raise SIGSEGV. Less pleasant. =( ---------------------------------------------------------------------- You can respond by visiting: https://sourceforge.net/tracker/?func=detail&atid=100976&aid=1604956&group_id=976Received on 2006-12-05 These mail archives are generated by hypermail. |
Page updated November 12, 2010.
web site info