From: Daniel Stenberg Date: Thu, 29 Jan 2004 11:23:36 +0000 (+0000) Subject: Dirk Manske fixed a flaw in the setting of the socket to non-blocking X-Git-Tag: curl-7_11_1~495 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=663d2080d14715602674f0afc2bd85b1438152d4;p=thirdparty%2Fcurl.git Dirk Manske fixed a flaw in the setting of the socket to non-blocking --- diff --git a/ares/CHANGES b/ares/CHANGES index 14c806c6af..d01629fbf2 100644 --- a/ares/CHANGES +++ b/ares/CHANGES @@ -5,6 +5,10 @@ doesn't want these improvements. The package is called 'c-ares' for now since I (Daniel Stenberg) want this for use within the curl project (hence the letter C) and it makes a nice pun. +* January 29, 2004: + +- Dirk Manske fixed how the socket is set non-blocking. + * January 4, 2004: - Dominick Meglio made the private gettimeofday() become ares_gettimeofday() diff --git a/ares/ares_process.c b/ares/ares_process.c index ee9623ac5a..b90049e605 100644 --- a/ares/ares_process.c +++ b/ares/ares_process.c @@ -464,12 +464,14 @@ static int open_tcp_socket(ares_channel channel, struct server_state *server) flags = 1; ioctlsocket(s, FIONBIO, &flags); #else - if (fcntl(s, F_GETFL, &flags) == -1) + flags = fcntl(s, F_GETFL, 0); + + if (flags == -1) { close(s); return -1; } - flags &= O_NONBLOCK; + flags |= O_NONBLOCK; if (fcntl(s, F_SETFL, flags) == -1) { close(s);