From: Dan Fandrich Date: Tue, 14 Oct 2008 23:52:36 +0000 (+0000) Subject: Added signal-based resolver timeout issue X-Git-Tag: curl-7_19_1~149 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=9b3f863cf5b34fc0c57a369e36dea18889093ad8;p=thirdparty%2Fcurl.git Added signal-based resolver timeout issue --- diff --git a/docs/TODO b/docs/TODO index 39ce320394..7f4c021914 100644 --- a/docs/TODO +++ b/docs/TODO @@ -18,6 +18,7 @@ 1.4 Get IP address 1.5 c-ares ipv6 1.6 configure-based info in public headers + 1.7 signal-based resolver timeouts 2. libcurl - multi interface 2.1 More non-blocking @@ -161,6 +162,18 @@ The remaining problems to solve involve the platforms that can't run configure. +1.7 signal-based resolver timeouts + + libcurl built without an asynchronous resolver library uses alarm() to time + out DNS lookups. When a timeout occurs, this causes libcurl to jump from the + signal handler back into the library with a sigsetjmp, which effectively + causes libcurl to continue running within the signal handler. This is + non-portable and could cause problems on some platforms. A discussion on the + problem is available at http://curl.haxx.se/mail/lib-2008-09/0197.html + + Also, alarm() provides timeout resolution only to the nearest second. alarm + ought to be replaced by setitimer on systems that support it. + 2. libcurl - multi interface 2.1 More non-blocking