From: Daniel Stenberg Date: Mon, 6 Mar 2017 08:21:01 +0000 (+0100) Subject: ares: return error at once if timed out before name resolve starts X-Git-Tag: curl-7_54_0~173 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=29be83ee74880030a16af46396ee83a3d8ba724b;p=thirdparty%2Fcurl.git ares: return error at once if timed out before name resolve starts Pointed-out-by: Ray Satiro Bug: https://curl.haxx.se/mail/lib-2017-03/0004.html --- diff --git a/lib/asyn-ares.c b/lib/asyn-ares.c index c038c2a3f1..ae73d05024 100644 --- a/lib/asyn-ares.c +++ b/lib/asyn-ares.c @@ -5,7 +5,7 @@ * | (__| |_| | _ <| |___ * \___|\___/|_| \_\_____| * - * Copyright (C) 1998 - 2016, Daniel Stenberg, , et al. + * Copyright (C) 1998 - 2017, Daniel Stenberg, , et al. * * This software is licensed as described in the file COPYING, which * you should have received as part of this distribution. The terms @@ -359,6 +359,11 @@ CURLcode Curl_resolver_wait_resolv(struct connectdata *conn, struct Curl_dns_entry *temp_entry; timeout = Curl_timeleft(data, &now, TRUE); + if(timeout < 0) { + /* already expired! */ + connclose(conn, "Timed out before name resolve started"); + return CURLE_OPERATION_TIMEDOUT; + } if(!timeout) timeout = CURL_TIMEOUT_RESOLVE * 1000; /* default name resolve timeout */