- Refactored a lot of timeout code into a few functions in an attempt to make
them all use the same (hopefully correct) logic to make it less error-prone and easier to introduce library-wide where it should be used.
This commit is contained in:
		
							
								
								
									
										5
									
								
								CHANGES
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								CHANGES
									
									
									
									
									
								
							| @@ -6,6 +6,11 @@ | |||||||
|  |  | ||||||
|                                   Changelog |                                   Changelog | ||||||
|  |  | ||||||
|  | Daniel S (7 Feb 2008) | ||||||
|  | - Refactored a lot of timeout code into a few functions in an attempt to make | ||||||
|  |   them all use the same (hopefully correct) logic to make it less error-prone | ||||||
|  |   and easier to introduce library-wide where it should be used. | ||||||
|  |  | ||||||
| Yang Tse (6 Feb 2008) | Yang Tse (6 Feb 2008) | ||||||
| - Fix an issue in strdup replacement function when dealing with absolutely | - Fix an issue in strdup replacement function when dealing with absolutely | ||||||
|   huge strings. Only systems without a standard strdup would be affected. |   huge strings. Only systems without a standard strdup would be affected. | ||||||
|   | |||||||
| @@ -32,6 +32,7 @@ New curl mirrors: | |||||||
| This release would not have looked like this without help, code, reports and | This release would not have looked like this without help, code, reports and | ||||||
| advice from friends like these: | advice from friends like these: | ||||||
|  |  | ||||||
|  Michal Marek, Dmitry Kurochkin, Niklas Angebrand |  Michal Marek, Dmitry Kurochkin, Niklas Angebrand, G<>nter Knauf, Yang Tse, | ||||||
|  |  Dan Fandrich | ||||||
|  |  | ||||||
|         Thanks! (and sorry if I forgot to mention someone) |         Thanks! (and sorry if I forgot to mention someone) | ||||||
|   | |||||||
							
								
								
									
										138
									
								
								lib/connect.c
									
									
									
									
									
								
							
							
						
						
									
										138
									
								
								lib/connect.c
									
									
									
									
									
								
							| @@ -101,6 +101,66 @@ singleipconnect(struct connectdata *conn, | |||||||
|                 long timeout_ms, |                 long timeout_ms, | ||||||
|                 bool *connected); |                 bool *connected); | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * Curl_timeleft() returns the amount of milliseconds left allowed for the | ||||||
|  |  * transfer/connection. If the value is negative, the timeout time has already | ||||||
|  |  * elapsed. | ||||||
|  |  * | ||||||
|  |  * If 'nowp' is non-NULL, it points to the current time. | ||||||
|  |  * 'duringconnect' is FALSE if not during a connect, as then of course the | ||||||
|  |  * connect timeout is not taken into account! | ||||||
|  |  */ | ||||||
|  | long Curl_timeleft(struct connectdata *conn, | ||||||
|  |                    struct timeval *nowp, | ||||||
|  |                    bool duringconnect) | ||||||
|  | { | ||||||
|  |   struct SessionHandle *data = conn->data; | ||||||
|  |   int timeout_set = 0; | ||||||
|  |   long timeout_ms = duringconnect?DEFAULT_CONNECT_TIMEOUT:0; | ||||||
|  |   struct timeval now; | ||||||
|  |  | ||||||
|  |   /* if a timeout is set, use the most restrictive one */ | ||||||
|  |  | ||||||
|  |   if(data->set.timeout > 0) | ||||||
|  |     timeout_set |= 1; | ||||||
|  |   if(duringconnect && (data->set.connecttimeout > 0)) | ||||||
|  |     timeout_set |= 2; | ||||||
|  |  | ||||||
|  |   switch (timeout_set) { | ||||||
|  |   case 1: | ||||||
|  |     timeout_ms = data->set.timeout; | ||||||
|  |     break; | ||||||
|  |   case 2: | ||||||
|  |     timeout_ms = data->set.connecttimeout; | ||||||
|  |     break; | ||||||
|  |   case 3: | ||||||
|  |     if(data->set.timeout < data->set.connecttimeout) | ||||||
|  |       timeout_ms = data->set.timeout; | ||||||
|  |     else | ||||||
|  |       timeout_ms = data->set.connecttimeout; | ||||||
|  |     break; | ||||||
|  |   default: | ||||||
|  |     /* use the default */ | ||||||
|  |     if(!duringconnect) | ||||||
|  |       /* if we're not during connect, there's no default timeout so if we're | ||||||
|  |          at zero we better just return zero and not make it a negative number | ||||||
|  |          by the math below */ | ||||||
|  |       return 0; | ||||||
|  |     break; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   if(!nowp) { | ||||||
|  |     now = Curl_tvnow(); | ||||||
|  |     nowp = &now; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   /* substract elapsed time */ | ||||||
|  |   timeout_ms -= Curl_tvdiff(*nowp, data->progress.t_startsingle); | ||||||
|  |  | ||||||
|  |   return timeout_ms; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Curl_nonblock() set the given socket to either blocking or non-blocking |  * Curl_nonblock() set the given socket to either blocking or non-blocking | ||||||
|  * mode based on the 'nonblock' boolean argument. This function is highly |  * mode based on the 'nonblock' boolean argument. This function is highly | ||||||
| @@ -533,42 +593,33 @@ CURLcode Curl_is_connected(struct connectdata *conn, | |||||||
|   CURLcode code = CURLE_OK; |   CURLcode code = CURLE_OK; | ||||||
|   curl_socket_t sockfd = conn->sock[sockindex]; |   curl_socket_t sockfd = conn->sock[sockindex]; | ||||||
|   long allow = DEFAULT_CONNECT_TIMEOUT; |   long allow = DEFAULT_CONNECT_TIMEOUT; | ||||||
|   long allow_total = 0; |  | ||||||
|   long has_passed; |  | ||||||
|  |  | ||||||
|   DEBUGASSERT(sockindex >= FIRSTSOCKET && sockindex <= SECONDARYSOCKET); |   DEBUGASSERT(sockindex >= FIRSTSOCKET && sockindex <= SECONDARYSOCKET); | ||||||
|  |  | ||||||
|   *connected = FALSE; /* a very negative world view is best */ |   *connected = FALSE; /* a very negative world view is best */ | ||||||
|  |  | ||||||
|   /* Evaluate in milliseconds how much time that has passed */ |  | ||||||
|   has_passed = Curl_tvdiff(Curl_tvnow(), data->progress.t_startsingle); |  | ||||||
|  |  | ||||||
|   /* subtract the most strict timeout of the ones */ |  | ||||||
|   if(data->set.timeout && data->set.connecttimeout) { |  | ||||||
|     if(data->set.timeout < data->set.connecttimeout) |  | ||||||
|       allow_total = allow = data->set.timeout; |  | ||||||
|     else |  | ||||||
|       allow = data->set.connecttimeout; |  | ||||||
|   } |  | ||||||
|   else if(data->set.timeout) { |  | ||||||
|     allow_total = allow = data->set.timeout; |  | ||||||
|   } |  | ||||||
|   else if(data->set.connecttimeout) { |  | ||||||
|     allow = data->set.connecttimeout; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   if(has_passed > allow ) { |  | ||||||
|     /* time-out, bail out, go home */ |  | ||||||
|     failf(data, "Connection time-out after %ld ms", has_passed); |  | ||||||
|     return CURLE_OPERATION_TIMEDOUT; |  | ||||||
|   } |  | ||||||
|   if(conn->bits.tcpconnect) { |   if(conn->bits.tcpconnect) { | ||||||
|     /* we are connected already! */ |     /* we are connected already! */ | ||||||
|  |     long allow_total = 0; | ||||||
|  |  | ||||||
|  |     /* subtract the most strict timeout of the ones */ | ||||||
|  |     if(data->set.timeout) | ||||||
|  |       allow_total = data->set.timeout; | ||||||
|  |  | ||||||
|     Curl_expire(data, allow_total); |     Curl_expire(data, allow_total); | ||||||
|     *connected = TRUE; |     *connected = TRUE; | ||||||
|     return CURLE_OK; |     return CURLE_OK; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |   /* figure out how long time we have left to connect */ | ||||||
|  |   allow = Curl_timeleft(conn, NULL, TRUE); | ||||||
|  |  | ||||||
|  |   if(allow < 0) { | ||||||
|  |     /* time-out, bail out, go home */ | ||||||
|  |     failf(data, "Connection time-out"); | ||||||
|  |     return CURLE_OPERATION_TIMEDOUT; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   Curl_expire(data, allow); |   Curl_expire(data, allow); | ||||||
|  |  | ||||||
|   /* check for connect without timeout as we want to return immediately */ |   /* check for connect without timeout as we want to return immediately */ | ||||||
| @@ -821,7 +872,6 @@ CURLcode Curl_connecthost(struct connectdata *conn,  /* context */ | |||||||
|   int num_addr; |   int num_addr; | ||||||
|   Curl_addrinfo *ai; |   Curl_addrinfo *ai; | ||||||
|   Curl_addrinfo *curr_addr; |   Curl_addrinfo *curr_addr; | ||||||
|   int timeout_set = 0; |  | ||||||
|  |  | ||||||
|   struct timeval after; |   struct timeval after; | ||||||
|   struct timeval before = Curl_tvnow(); |   struct timeval before = Curl_tvnow(); | ||||||
| @@ -834,39 +884,13 @@ CURLcode Curl_connecthost(struct connectdata *conn,  /* context */ | |||||||
|  |  | ||||||
|   *connected = FALSE; /* default to not connected */ |   *connected = FALSE; /* default to not connected */ | ||||||
|  |  | ||||||
|   /* if a timeout is set, use the most restrictive one */ |   /* get the timeout left */ | ||||||
|  |   timeout_ms = Curl_timeleft(conn, &before, TRUE); | ||||||
|  |  | ||||||
|   if(data->set.timeout > 0) |   if(timeout_ms < 0) { | ||||||
|     timeout_set += 1; |     /* a precaution, no need to continue if time already is up */ | ||||||
|   if(data->set.connecttimeout > 0) |     failf(data, "Connection time-out"); | ||||||
|     timeout_set += 2; |     return CURLE_OPERATION_TIMEDOUT; | ||||||
|  |  | ||||||
|   switch (timeout_set) { |  | ||||||
|   case 1: |  | ||||||
|     timeout_ms = data->set.timeout; |  | ||||||
|     break; |  | ||||||
|   case 2: |  | ||||||
|     timeout_ms = data->set.connecttimeout; |  | ||||||
|     break; |  | ||||||
|   case 3: |  | ||||||
|     if(data->set.timeout < data->set.connecttimeout) |  | ||||||
|       timeout_ms = data->set.timeout; |  | ||||||
|     else |  | ||||||
|       timeout_ms = data->set.connecttimeout; |  | ||||||
|     break; |  | ||||||
|   default: |  | ||||||
|     timeout_ms = DEFAULT_CONNECT_TIMEOUT; |  | ||||||
|     break; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   if(timeout_set > 0) { |  | ||||||
|     /* if a timeout was already set, substract elapsed time */ |  | ||||||
|     timeout_ms -= Curl_tvdiff(before, data->progress.t_startsingle); |  | ||||||
|     if(timeout_ms < 0) { |  | ||||||
|       /* a precaution, no need to continue if time already is up */ |  | ||||||
|       failf(data, "Connection time-out"); |  | ||||||
|       return CURLE_OPERATION_TIMEDOUT; |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
|   Curl_expire(data, timeout_ms); |   Curl_expire(data, timeout_ms); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,7 +7,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
| @@ -31,14 +31,20 @@ CURLcode Curl_is_connected(struct connectdata *conn, | |||||||
|                            bool *connected); |                            bool *connected); | ||||||
|  |  | ||||||
| CURLcode Curl_connecthost(struct connectdata *conn, | CURLcode Curl_connecthost(struct connectdata *conn, | ||||||
|                           const struct Curl_dns_entry *host, /* connect to this */ |                           const struct Curl_dns_entry *host, /* connect to | ||||||
|  |                                                                 this */ | ||||||
|                           curl_socket_t *sockconn, /* not set if error */ |                           curl_socket_t *sockconn, /* not set if error */ | ||||||
|                           Curl_addrinfo **addr, /* the one we used */ |                           Curl_addrinfo **addr, /* the one we used */ | ||||||
|                           bool *connected /* truly connected? */ |                           bool *connected); /* truly connected? */ | ||||||
|                           ); |  | ||||||
|  |  | ||||||
| CURLcode Curl_store_ip_addr(struct connectdata *conn); | CURLcode Curl_store_ip_addr(struct connectdata *conn); | ||||||
|  |  | ||||||
|  | /* generic function that returns how much time there's left to run, according | ||||||
|  |    to the timeouts set */ | ||||||
|  | long Curl_timeleft(struct connectdata *conn, | ||||||
|  |                    struct timeval *nowp, | ||||||
|  |                    bool duringconnect); | ||||||
|  |  | ||||||
| #define DEFAULT_CONNECT_TIMEOUT 300000 /* milliseconds == five minutes */ | #define DEFAULT_CONNECT_TIMEOUT 300000 /* milliseconds == five minutes */ | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|   | |||||||
							
								
								
									
										39
									
								
								lib/ftp.c
									
									
									
									
									
								
							
							
						
						
									
										39
									
								
								lib/ftp.c
									
									
									
									
									
								
							| @@ -300,43 +300,14 @@ static bool isBadFtpString(const char *string) | |||||||
|  */ |  */ | ||||||
| static CURLcode AllowServerConnect(struct connectdata *conn) | static CURLcode AllowServerConnect(struct connectdata *conn) | ||||||
| { | { | ||||||
|   long timeout_ms; |  | ||||||
|   struct SessionHandle *data = conn->data; |   struct SessionHandle *data = conn->data; | ||||||
|   curl_socket_t sock = conn->sock[SECONDARYSOCKET]; |   curl_socket_t sock = conn->sock[SECONDARYSOCKET]; | ||||||
|   int timeout_set = 0; |   long timeout_ms = Curl_timeleft(conn, NULL, TRUE); | ||||||
|  |  | ||||||
|   /* if a timeout is set, use the most restrictive one */ |   if(timeout_ms < 0) { | ||||||
|  |     /* if a timeout was already reached, bail out */ | ||||||
|   if(data->set.timeout > 0) |     failf(data, "Timed out before server could connect to us"); | ||||||
|     timeout_set += 1; |     return CURLE_OPERATION_TIMEDOUT; | ||||||
|   if(data->set.connecttimeout > 0) |  | ||||||
|     timeout_set += 2; |  | ||||||
|  |  | ||||||
|   switch (timeout_set) { |  | ||||||
|   case 1: |  | ||||||
|     timeout_ms = data->set.timeout; |  | ||||||
|     break; |  | ||||||
|   case 2: |  | ||||||
|     timeout_ms = data->set.connecttimeout; |  | ||||||
|     break; |  | ||||||
|   case 3: |  | ||||||
|     if(data->set.timeout < data->set.connecttimeout) |  | ||||||
|       timeout_ms = data->set.timeout; |  | ||||||
|     else |  | ||||||
|       timeout_ms = data->set.connecttimeout; |  | ||||||
|     break; |  | ||||||
|   default: |  | ||||||
|     timeout_ms = 60000; /* 60 seconds default timeout */ |  | ||||||
|     break; |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   if(timeout_set > 0) { |  | ||||||
|     /* if a timeout was already set, substract elapsed time */ |  | ||||||
|     timeout_ms -= Curl_tvdiff(Curl_tvnow(), conn->now); |  | ||||||
|     if(timeout_ms < 0) { |  | ||||||
|       failf(data, "Timed out before server could connect to us"); |  | ||||||
|       return CURLE_OPERATION_TIMEDOUT; |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   switch (Curl_socket_ready(sock, CURL_SOCKET_BAD, (int)timeout_ms)) { |   switch (Curl_socket_ready(sock, CURL_SOCKET_BAD, (int)timeout_ms)) { | ||||||
|   | |||||||
							
								
								
									
										20
									
								
								lib/gtls.c
									
									
									
									
									
								
							
							
						
						
									
										20
									
								
								lib/gtls.c
									
									
									
									
									
								
							| @@ -5,7 +5,7 @@ | |||||||
|  *                            | (__| |_| |  _ <| |___ |  *                            | (__| |_| |  _ <| |___ | ||||||
|  *                             \___|\___/|_| \_\_____| |  *                             \___|\___/|_| \_\_____| | ||||||
|  * |  * | ||||||
|  * Copyright (C) 1998 - 2007, Daniel Stenberg, <daniel@haxx.se>, et al. |  * Copyright (C) 1998 - 2008, Daniel Stenberg, <daniel@haxx.se>, et al. | ||||||
|  * |  * | ||||||
|  * This software is licensed as described in the file COPYING, which |  * This software is licensed as described in the file COPYING, which | ||||||
|  * you should have received as part of this distribution. The terms |  * you should have received as part of this distribution. The terms | ||||||
| @@ -154,23 +154,7 @@ static CURLcode handshake(struct connectdata *conn, | |||||||
|     rc = gnutls_handshake(session); |     rc = gnutls_handshake(session); | ||||||
|  |  | ||||||
|     if((rc == GNUTLS_E_AGAIN) || (rc == GNUTLS_E_INTERRUPTED)) { |     if((rc == GNUTLS_E_AGAIN) || (rc == GNUTLS_E_INTERRUPTED)) { | ||||||
|       long timeout_ms = DEFAULT_CONNECT_TIMEOUT; |       long timeout_ms = Curl_connecttimeleft(conn, NULL, duringconnect); | ||||||
|       long has_passed; |  | ||||||
|  |  | ||||||
|       if(duringconnect && data->set.connecttimeout) |  | ||||||
|         timeout_ms = data->set.connecttimeout; |  | ||||||
|  |  | ||||||
|       if(data->set.timeout) { |  | ||||||
|         /* get the strictest timeout of the ones converted to milliseconds */ |  | ||||||
|         if(data->set.timeout < timeout_ms) |  | ||||||
|           timeout_ms = data->set.timeout; |  | ||||||
|       } |  | ||||||
|  |  | ||||||
|       /* Evaluate in milliseconds how much time that has passed */ |  | ||||||
|       has_passed = Curl_tvdiff(Curl_tvnow(), data->progress.t_startsingle); |  | ||||||
|  |  | ||||||
|       /* subtract the passed time */ |  | ||||||
|       timeout_ms -= has_passed; |  | ||||||
|  |  | ||||||
|       if(timeout_ms < 0) { |       if(timeout_ms < 0) { | ||||||
|         /* a precaution, no need to continue if time already is up */ |         /* a precaution, no need to continue if time already is up */ | ||||||
|   | |||||||
							
								
								
									
										13
									
								
								lib/qssl.c
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								lib/qssl.c
									
									
									
									
									
								
							| @@ -172,17 +172,8 @@ static CURLcode Curl_qsossl_handshake(struct connectdata * conn, int sockindex) | |||||||
|   if(!data->set.ssl.verifyhost) |   if(!data->set.ssl.verifyhost) | ||||||
|     h->exitPgm = Curl_qsossl_trap_cert; |     h->exitPgm = Curl_qsossl_trap_cert; | ||||||
|  |  | ||||||
|   if(data->set.connecttimeout) { |   /* figure out how long time we should wait at maximum */ | ||||||
|     timeout_ms = data->set.connecttimeout; |   timeout_ms = Curl_timeleft(conn, NULL, TRUE); | ||||||
|  |  | ||||||
|     if(data->set.timeout) |  | ||||||
|       if(timeout_ms > data->set.timeout) |  | ||||||
|         timeout_ms = data->set.timeout; |  | ||||||
|     } |  | ||||||
|   else if(data->set.timeout) |  | ||||||
|     timeout_ms = data->set.timeout; |  | ||||||
|   else |  | ||||||
|     timeout_ms = DEFAULT_CONNECT_TIMEOUT; |  | ||||||
|  |  | ||||||
|   /* SSL_Handshake() timeout resolution is second, so round up. */ |   /* SSL_Handshake() timeout resolution is second, so round up. */ | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										26
									
								
								lib/socks.c
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								lib/socks.c
									
									
									
									
									
								
							| @@ -138,18 +138,7 @@ CURLcode Curl_SOCKS4(const char *proxy_name, | |||||||
|   struct SessionHandle *data = conn->data; |   struct SessionHandle *data = conn->data; | ||||||
|  |  | ||||||
|   /* get timeout */ |   /* get timeout */ | ||||||
|   if(data->set.timeout && data->set.connecttimeout) { |   timeout = Curl_timeleft(conn, NULL, TRUE); | ||||||
|     if(data->set.timeout < data->set.connecttimeout) |  | ||||||
|       timeout = data->set.timeout; |  | ||||||
|     else |  | ||||||
|       timeout = data->set.connecttimeout; |  | ||||||
|   } |  | ||||||
|   else if(data->set.timeout) |  | ||||||
|     timeout = data->set.timeout; |  | ||||||
|   else if(data->set.connecttimeout) |  | ||||||
|     timeout = data->set.connecttimeout; |  | ||||||
|   else |  | ||||||
|     timeout = DEFAULT_CONNECT_TIMEOUT; |  | ||||||
|  |  | ||||||
|   Curl_nonblock(sock, FALSE); |   Curl_nonblock(sock, FALSE); | ||||||
|  |  | ||||||
| @@ -403,18 +392,7 @@ CURLcode Curl_SOCKS5(const char *proxy_name, | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   /* get timeout */ |   /* get timeout */ | ||||||
|   if(data->set.timeout && data->set.connecttimeout) { |   timeout = Curl_timeleft(conn, NULL, TRUE); | ||||||
|     if(data->set.timeout < data->set.connecttimeout) |  | ||||||
|       timeout = data->set.timeout; |  | ||||||
|     else |  | ||||||
|       timeout = data->set.connecttimeout; |  | ||||||
|   } |  | ||||||
|   else if(data->set.timeout) |  | ||||||
|     timeout = data->set.timeout; |  | ||||||
|   else if(data->set.connecttimeout) |  | ||||||
|     timeout = data->set.connecttimeout; |  | ||||||
|   else |  | ||||||
|     timeout = DEFAULT_CONNECT_TIMEOUT; |  | ||||||
|  |  | ||||||
|   Curl_nonblock(sock, TRUE); |   Curl_nonblock(sock, TRUE); | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										29
									
								
								lib/ssluse.c
									
									
									
									
									
								
							
							
						
						
									
										29
									
								
								lib/ssluse.c
									
									
									
									
									
								
							| @@ -1448,40 +1448,17 @@ ossl_connect_step2(struct connectdata *conn, | |||||||
| { | { | ||||||
|   struct SessionHandle *data = conn->data; |   struct SessionHandle *data = conn->data; | ||||||
|   int err; |   int err; | ||||||
|   long has_passed; |  | ||||||
|   struct ssl_connect_data *connssl = &conn->ssl[sockindex]; |   struct ssl_connect_data *connssl = &conn->ssl[sockindex]; | ||||||
|  |  | ||||||
|   DEBUGASSERT(ssl_connect_2 == connssl->connecting_state |   DEBUGASSERT(ssl_connect_2 == connssl->connecting_state | ||||||
|              || ssl_connect_2_reading == connssl->connecting_state |              || ssl_connect_2_reading == connssl->connecting_state | ||||||
|              || ssl_connect_2_writing == connssl->connecting_state); |              || ssl_connect_2_writing == connssl->connecting_state); | ||||||
|  |  | ||||||
|   /* Find out if any timeout is set. If not, use 300 seconds. |   /* Find out how much more time we're allowed */ | ||||||
|      Otherwise, figure out the most strict timeout of the two possible one |   *timeout_ms = Curl_timeleft(conn, NULL, TRUE); | ||||||
|      and then how much time that has elapsed to know how much time we |  | ||||||
|      allow for the connect call */ |  | ||||||
|   if(data->set.timeout && data->set.connecttimeout) { |  | ||||||
|     /* get the most strict timeout of the ones converted to milliseconds */ |  | ||||||
|     if(data->set.timeout<data->set.connecttimeout) |  | ||||||
|       *timeout_ms = data->set.timeout; |  | ||||||
|     else |  | ||||||
|       *timeout_ms = data->set.connecttimeout; |  | ||||||
|   } |  | ||||||
|   else if(data->set.timeout) |  | ||||||
|     *timeout_ms = data->set.timeout; |  | ||||||
|   else if(data->set.connecttimeout) |  | ||||||
|     *timeout_ms = data->set.connecttimeout; |  | ||||||
|   else |  | ||||||
|     /* no particular time-out has been set */ |  | ||||||
|     *timeout_ms = DEFAULT_CONNECT_TIMEOUT; |  | ||||||
|  |  | ||||||
|   /* Evaluate in milliseconds how much time that has passed */ |  | ||||||
|   has_passed = Curl_tvdiff(Curl_tvnow(), data->progress.t_startsingle); |  | ||||||
|  |  | ||||||
|   /* subtract the passed time */ |  | ||||||
|   *timeout_ms -= has_passed; |  | ||||||
|  |  | ||||||
|   if(*timeout_ms < 0) { |   if(*timeout_ms < 0) { | ||||||
|     /* a precaution, no need to continue if time already is up */ |     /* no need to continue if time already is up */ | ||||||
|     failf(data, "SSL connection timeout"); |     failf(data, "SSL connection timeout"); | ||||||
|     return CURLE_OPERATION_TIMEDOUT; |     return CURLE_OPERATION_TIMEDOUT; | ||||||
|   } |   } | ||||||
|   | |||||||
							
								
								
									
										17
									
								
								lib/tftp.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								lib/tftp.c
									
									
									
									
									
								
							| @@ -114,7 +114,7 @@ typedef enum { | |||||||
|   TFTP_ERR_ILLEGAL, |   TFTP_ERR_ILLEGAL, | ||||||
|   TFTP_ERR_UNKNOWNID, |   TFTP_ERR_UNKNOWNID, | ||||||
|   TFTP_ERR_EXISTS, |   TFTP_ERR_EXISTS, | ||||||
|   TFTP_ERR_NOSUCHUSER,	/* This will never be triggered by this code */ |   TFTP_ERR_NOSUCHUSER,  /* This will never be triggered by this code */ | ||||||
|  |  | ||||||
|   /* The remaining error codes are internal to curl */ |   /* The remaining error codes are internal to curl */ | ||||||
|   TFTP_ERR_NONE = -100, |   TFTP_ERR_NONE = -100, | ||||||
| @@ -194,12 +194,14 @@ static void tftp_set_timeouts(tftp_state_data_t *state) | |||||||
|  |  | ||||||
|   struct SessionHandle *data = state->conn->data; |   struct SessionHandle *data = state->conn->data; | ||||||
|   time_t maxtime, timeout; |   time_t maxtime, timeout; | ||||||
|  |   long timeout_ms; | ||||||
|  |  | ||||||
|   time(&state->start_time); |   time(&state->start_time); | ||||||
|  |  | ||||||
|   if(state->state == TFTP_STATE_START) { |   if(state->state == TFTP_STATE_START) { | ||||||
|     /* Compute drop-dead time */ |     /* Compute drop-dead time */ | ||||||
|     maxtime = (time_t)(data->set.connecttimeout/1000L? |     timeout_ms = Curl_timeleft(state->conn, NULL, TRUE); | ||||||
|                        data->set.connecttimeout/1000L:30); |     maxtime = (time_t)(timeout_ms + 500) / 1000; | ||||||
|     state->max_time = state->start_time+maxtime; |     state->max_time = state->start_time+maxtime; | ||||||
|  |  | ||||||
|     /* Set per-block timeout to total */ |     /* Set per-block timeout to total */ | ||||||
| @@ -219,10 +221,13 @@ static void tftp_set_timeouts(tftp_state_data_t *state) | |||||||
|  |  | ||||||
|   } |   } | ||||||
|   else { |   else { | ||||||
|  |  | ||||||
|     /* Compute drop-dead time */ |     /* Compute drop-dead time */ | ||||||
|     maxtime = (time_t)(data->set.timeout/1000L? |     timeout_ms = Curl_timeleft(state->conn, NULL, TRUE); | ||||||
|                        data->set.timeout/1000L:3600); |     if(timeout_ms > 0) | ||||||
|  |       maxtime = (time_t)(timeout_ms + 500) / 1000; | ||||||
|  |     else | ||||||
|  |       maxtime = 3600; | ||||||
|  |  | ||||||
|     state->max_time = state->start_time+maxtime; |     state->max_time = state->start_time+maxtime; | ||||||
|  |  | ||||||
|     /* Set per-block timeout to 10% of total */ |     /* Set per-block timeout to 10% of total */ | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Daniel Stenberg
					Daniel Stenberg