From: Daniel Stenberg Date: Wed, 23 May 2018 22:21:37 +0000 (+0200) Subject: multi: provide a socket to wait for in Curl_protocol_getsock X-Git-Tag: curl-7_61_0~127 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=3e0dee065f3a286d5ea85e767d2369a4061c8a55;p=curl multi: provide a socket to wait for in Curl_protocol_getsock ... even when there's no protocol specific handler setup. Bug: https://curl.haxx.se/mail/lib-2018-05/0062.html Reported-by: Sean Miller Closes #2600 --- diff --git a/lib/url.c b/lib/url.c index 701f83ab3..411a0c814 100644 --- a/lib/url.c +++ b/lib/url.c @@ -1554,7 +1554,11 @@ int Curl_protocol_getsock(struct connectdata *conn, { if(conn->handler->proto_getsock) return conn->handler->proto_getsock(conn, socks, numsocks); - return GETSOCK_BLANK; + /* Backup getsock logic. Since there is a live socket in use, we must wait + for it or it will be removed from watching when the multi_socket API is + used. */ + socks[0] = conn->sock[FIRSTSOCKET]; + return GETSOCK_READSOCK(0) | GETSOCK_WRITESOCK(0); } int Curl_doing_getsock(struct connectdata *conn,