From fb2e71b9bd352bca7e3a5533c69bd236132a5d7a Mon Sep 17 00:00:00 2001 From: Daniel Stenberg Date: Thu, 19 Jun 2008 08:31:22 +0000 Subject: [PATCH] - Dengminwen found a bug in the connection re-use function when using the multi interface with pipelining enabled as it would wrongly check for, detect and close "dead connections" even though that connection was already in use! --- CHANGES | 6 ++++++ RELEASE-NOTES | 3 ++- lib/url.c | 7 ++++--- 3 files changed, 12 insertions(+), 4 deletions(-) diff --git a/CHANGES b/CHANGES index aa6997951..1d137577c 100644 --- a/CHANGES +++ b/CHANGES @@ -6,6 +6,12 @@ Changelog +Daniel Stenberg (19 Jun 2008) +- Dengminwen found a bug in the connection re-use function when using the + multi interface with pipelining enabled as it would wrongly check for, + detect and close "dead connections" even though that connection was already + in use! + Daniel Fandrich (18 Jun 2008) - Added SSH failure test cases 628-632 diff --git a/RELEASE-NOTES b/RELEASE-NOTES index 50ea7ad7b..3201397e2 100644 --- a/RELEASE-NOTES +++ b/RELEASE-NOTES @@ -20,6 +20,7 @@ This release includes the following bugfixes: o Fixed curl-config --ca o Fixed the multi interface connection re-use with NSS-built libcurl + o connection re-use when using the multi interface with pipelining enabled This release includes the following known bugs: @@ -37,6 +38,6 @@ This release would not have looked like this without help, code, reports and advice from friends like these: Lenny Rachitsky, Axel Tillequin, Arnaud Ebalard, Yang Tse, Dan Fandrich, - Rob Crittenden + Rob Crittenden, Dengminwen Thanks! (and sorry if I forgot to mention someone) diff --git a/lib/url.c b/lib/url.c index a7f1a0c1a..6391edb28 100644 --- a/lib/url.c +++ b/lib/url.c @@ -2511,9 +2511,10 @@ ConnectionExists(struct SessionHandle *data, } if(match) { - if(pipeLen == 0) { - /* The check for a dead socket makes sense only if there - are no handles in pipeline */ + if(!pipeLen && !check->inuse) { + /* The check for a dead socket makes sense only if there are no + handles in pipeline and the connection isn't already marked in + use */ bool dead = SocketIsDead(check->sock[FIRSTSOCKET]); if(dead) { check->data = data; -- 2.40.0