* resolv/res_send.c (send_dg): Create sockets with non-blocking

flag already set.
This commit is contained in:
Ulrich Drepper 2008-12-02 06:21:18 +00:00
parent 30c063710e
commit 9744268c10
2 changed files with 50 additions and 11 deletions

View File

@ -1,5 +1,8 @@
2008-12-01 Ulrich Drepper <drepper@redhat.com> 2008-12-01 Ulrich Drepper <drepper@redhat.com>
* resolv/res_send.c (send_dg): Create sockets with non-blocking
flag already set.
* stdlib/setenv.c (unsetenv): Don't search environment if it does * stdlib/setenv.c (unsetenv): Don't search environment if it does
not exist. not exist.
* stdlib/Makefile (tests): Add tst-unsetenv1. * stdlib/Makefile (tests): Add tst-unsetenv1.

View File

@ -95,6 +95,7 @@ static const char rcsid[] = "$BINDId: res_send.c,v 8.38 2000/03/30 20:16:51 vixi
#include <stdlib.h> #include <stdlib.h>
#include <string.h> #include <string.h>
#include <unistd.h> #include <unistd.h>
#include <kernel-features.h>
#if PACKETSZ > 65536 #if PACKETSZ > 65536
#define MAXPACKET PACKETSZ #define MAXPACKET PACKETSZ
@ -103,6 +104,13 @@ static const char rcsid[] = "$BINDId: res_send.c,v 8.38 2000/03/30 20:16:51 vixi
#endif #endif
#ifndef __ASSUME_O_CLOEXEC
static int __have_o_nonblock;
#else
# define __have_o_nonblock 0
#endif
/* From ev_streams.c. */ /* From ev_streams.c. */
static inline void static inline void
@ -920,6 +928,18 @@ send_dg(res_state statp,
if (EXT(statp).nssocks[ns] == -1) { if (EXT(statp).nssocks[ns] == -1) {
/* only try IPv6 if IPv6 NS and if not failed before */ /* only try IPv6 if IPv6 NS and if not failed before */
if ((EXT(statp).nscount6 > 0) && !statp->ipv6_unavail) { if ((EXT(statp).nscount6 > 0) && !statp->ipv6_unavail) {
if (__have_o_nonblock >= 0) {
EXT(statp).nssocks[ns] =
socket(PF_INET6, SOCK_DGRAM|SOCK_NONBLOCK,
0);
#ifndef __ASSUME_O_CLOEXEC
if (__have_o_nonblock == 0)
__have_o_nonblock
= (EXT(statp).nssocks[ns] == -1
&& errno == EINVAL ? -1 : 1);
#endif
}
if (__have_o_nonblock < 0)
EXT(statp).nssocks[ns] = EXT(statp).nssocks[ns] =
socket(PF_INET6, SOCK_DGRAM, 0); socket(PF_INET6, SOCK_DGRAM, 0);
if (EXT(statp).nssocks[ns] < 0) if (EXT(statp).nssocks[ns] < 0)
@ -929,8 +949,22 @@ send_dg(res_state statp,
else if (nsap->sin6_family == AF_INET) else if (nsap->sin6_family == AF_INET)
convaddr4to6(nsap); convaddr4to6(nsap);
} }
if (EXT(statp).nssocks[ns] < 0) if (EXT(statp).nssocks[ns] < 0) {
EXT(statp).nssocks[ns] = socket(PF_INET, SOCK_DGRAM, 0); if (__have_o_nonblock >= 0) {
EXT(statp).nssocks[ns]
= socket(PF_INET, SOCK_DGRAM|SOCK_NONBLOCK,
0);
#ifndef __ASSUME_O_CLOEXEC
if (__have_o_nonblock == 0)
__have_o_nonblock
= (EXT(statp).nssocks[ns] == -1
&& errno == EINVAL ? -1 : 1);
#endif
}
if (__have_o_nonblock < 0)
EXT(statp).nssocks[ns]
= socket(PF_INET, SOCK_DGRAM, 0);
}
if (EXT(statp).nssocks[ns] < 0) { if (EXT(statp).nssocks[ns] < 0) {
*terrno = errno; *terrno = errno;
Perror(statp, stderr, "socket(dg)", errno); Perror(statp, stderr, "socket(dg)", errno);
@ -955,6 +989,7 @@ send_dg(res_state statp,
__res_iclose(statp, false); __res_iclose(statp, false);
return (0); return (0);
} }
if (__have_o_nonblock < 0) {
/* Make socket non-blocking. */ /* Make socket non-blocking. */
int fl = __fcntl (EXT(statp).nssocks[ns], F_GETFL); int fl = __fcntl (EXT(statp).nssocks[ns], F_GETFL);
if (fl != -1) if (fl != -1)
@ -963,6 +998,7 @@ send_dg(res_state statp,
Dprint(statp->options & RES_DEBUG, Dprint(statp->options & RES_DEBUG,
(stdout, ";; new DG socket\n")) (stdout, ";; new DG socket\n"))
} }
}
/* /*
* Compute time for the total operation. * Compute time for the total operation.