- Jeff Pohlmeyer identified two problems: first a rather obscure problem with

the multi interface and connection re-use that could make a
  curl_multi_remove_handle() ruin a pointer in another handle.

  The second problem was less of an actual problem but more of minor quirk:
  the re-using of connections wasn't properly checking if the connection was
  marked for closure.
This commit is contained in:
Daniel Stenberg 2007-02-18 23:02:42 +00:00
parent 300cbc2e21
commit cbf58d88d0
6 changed files with 30 additions and 20 deletions

View File

@ -6,6 +6,15 @@
Changelog Changelog
Daniel (18 February 2007)
- Jeff Pohlmeyer identified two problems: first a rather obscure problem with
the multi interface and connection re-use that could make a
curl_multi_remove_handle() ruin a pointer in another handle.
The second problem was less of an actual problem but more of minor quirk:
the re-using of connections wasn't properly checking if the connection was
marked for closure.
Daniel (16 February 2007) Daniel (16 February 2007)
- Duncan Mac-Vicar Prett and Michal Marek reported problems with resetting - Duncan Mac-Vicar Prett and Michal Marek reported problems with resetting
CURLOPT_RANGE back to no range on an easy handle when using FTP. CURLOPT_RANGE back to no range on an easy handle when using FTP.

View File

@ -23,6 +23,7 @@ This release includes the following bugfixes:
o socks5 works o socks5 works
o builds fine with VC2005 o builds fine with VC2005
o CURLOPT_RANGE set to NULL resets the range for FTP o CURLOPT_RANGE set to NULL resets the range for FTP
o curl_multi_remove_handle() rare crash
This release includes the following known bugs: This release includes the following known bugs:
@ -40,6 +41,7 @@ This release would not have looked like this without help, code, reports and
advice from friends like these: advice from friends like these:
Yang Tse, Manfred Schwarb, Michael Wallner, Jeff Pohlmeyer, Shmulik Regev, Yang Tse, Manfred Schwarb, Michael Wallner, Jeff Pohlmeyer, Shmulik Regev,
Rob Crittenden, Robert A. Monat, Duncan Mac-Vicar Prett, Michal Marek Rob Crittenden, Robert A. Monat, Dan Fandrich, Duncan Mac-Vicar Prett,
Michal Marek
Thanks! (and sorry if I forgot to mention someone) Thanks! (and sorry if I forgot to mention someone)

View File

@ -7,9 +7,6 @@ may have been fixed since this was written!
--ftp-ssl-ccc on some servers. Recipe and instructions here: --ftp-ssl-ccc on some servers. Recipe and instructions here:
http://curl.haxx.se/mail/lib-2007-01/0210.html http://curl.haxx.se/mail/lib-2007-01/0210.html
41. Jeff Pohlmeyer's curl_multi_socket crashing case. Recipe and instructions
here: http://curl.haxx.se/mail/lib-2007-01/0022.html
40. HTTP Pipelining, NULL content 40. HTTP Pipelining, NULL content
http://curl.haxx.se/bug/view.cgi?id=1631566 http://curl.haxx.se/bug/view.cgi?id=1631566

View File

@ -1403,6 +1403,10 @@ CURLcode Curl_http_connect(struct connectdata *conn, bool *done)
data=conn->data; data=conn->data;
/* We default to persistent connections. We set this already in this connect
function to make the re-use checks properly be able to check this bit. */
conn->bits.close = FALSE;
/* If we are not using a proxy and we want a secure connection, perform SSL /* If we are not using a proxy and we want a secure connection, perform SSL
* initialization & connection now. If using a proxy with https, then we * initialization & connection now. If using a proxy with https, then we
* must tell the proxy to CONNECT to the host we want to talk to. Only * must tell the proxy to CONNECT to the host we want to talk to. Only
@ -1674,9 +1678,6 @@ CURLcode Curl_http(struct connectdata *conn, bool *done)
else else
http = data->reqdata.proto.http; http = data->reqdata.proto.http;
/* We default to persistent connections */
conn->bits.close = FALSE;
if ( (conn->protocol&(PROT_HTTP|PROT_FTP)) && if ( (conn->protocol&(PROT_HTTP|PROT_FTP)) &&
data->set.upload) { data->set.upload) {
httpreq = HTTPREQ_PUT; httpreq = HTTPREQ_PUT;

View File

@ -542,11 +542,10 @@ CURLMcode curl_multi_remove_handle(CURLM *multi_handle,
easy->easy_handle->dns.hostcachetype = HCACHE_NONE; easy->easy_handle->dns.hostcachetype = HCACHE_NONE;
} }
/* if we have a connection we must call Curl_done() here so that we /* we must call Curl_done() here (if we still "own it") so that we don't
don't leave a half-baked one around */ leave a half-baked one around */
if(easy->easy_conn) { if(easy->easy_conn &&
/* Set up the association right */ (easy->easy_conn->data == easy->easy_handle)) {
easy->easy_conn->data = easy->easy_handle;
/* Curl_done() clears the conn->data field to lose the association /* Curl_done() clears the conn->data field to lose the association
between the easy handle and the connection */ between the easy handle and the connection */

View File

@ -2030,7 +2030,8 @@ ConnectionExists(struct SessionHandle *data,
from the multi */ from the multi */
} }
infof(data, "Examining connection #%ld for reuse\n", check->connectindex); DEBUGF(infof(data, "Examining connection #%ld for reuse\n",
check->connectindex));
if(check->inuse && !canPipeline) { if(check->inuse && !canPipeline) {
/* can only happen within multi handles, and means that another easy /* can only happen within multi handles, and means that another easy
@ -2056,8 +2057,8 @@ ConnectionExists(struct SessionHandle *data,
continue; continue;
} }
if (data->state.is_in_pipeline && check->bits.close) { if (check->bits.close) {
/* Don't pick a connection that is going to be closed */ /* Don't pick a connection that is going to be closed. */
infof(data, "Connection #%ld has been marked for close, can't reuse\n", infof(data, "Connection #%ld has been marked for close, can't reuse\n",
check->connectindex); check->connectindex);
continue; continue;
@ -4136,8 +4137,9 @@ CURLcode Curl_async_resolved(struct connectdata *conn,
CURLcode Curl_done(struct connectdata **connp, CURLcode Curl_done(struct connectdata **connp,
CURLcode status, bool premature) /* an error if this is called after an CURLcode status, /* an error if this is called after an
error was detected */ error was detected */
bool premature)
{ {
CURLcode result; CURLcode result;
struct connectdata *conn = *connp; struct connectdata *conn = *connp;