2005-12-22 18:27:41 +03:00
|
|
|
/* $Id$ */
|
|
|
|
|
2007-04-03 22:25:18 +04:00
|
|
|
/* Copyright (C) 2005 - 2007, Daniel Stenberg
|
2005-12-22 18:27:41 +03:00
|
|
|
*
|
|
|
|
* Permission to use, copy, modify, and distribute this software and its
|
|
|
|
* documentation for any purpose and without fee is hereby granted, provided
|
|
|
|
* that the above copyright notice appear in all copies and that both that
|
|
|
|
* copyright notice and this permission notice appear in supporting
|
|
|
|
* documentation, and that the name of M.I.T. not be used in advertising or
|
|
|
|
* publicity pertaining to distribution of the software without specific,
|
|
|
|
* written prior permission. M.I.T. makes no representations about the
|
|
|
|
* suitability of this software for any purpose. It is provided "as is"
|
|
|
|
* without express or implied warranty.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "setup.h"
|
|
|
|
|
|
|
|
#ifdef HAVE_SYS_TIME_H
|
|
|
|
#include <sys/time.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "ares.h"
|
|
|
|
#include "ares_private.h"
|
|
|
|
|
|
|
|
int ares_getsock(ares_channel channel,
|
|
|
|
int *s,
|
|
|
|
int numsocks) /* size of the 'socks' array */
|
|
|
|
{
|
|
|
|
struct server_state *server;
|
|
|
|
int i;
|
|
|
|
int sockindex=0;
|
|
|
|
int bitmap = 0;
|
|
|
|
unsigned int setbits = 0xffffffff;
|
|
|
|
|
|
|
|
ares_socket_t *socks = (ares_socket_t *)s;
|
|
|
|
|
2007-09-29 23:26:59 +04:00
|
|
|
/* Are there any active queries? */
|
|
|
|
int active_queries = !ares__is_list_empty(&(channel->all_queries));
|
2005-12-22 18:27:41 +03:00
|
|
|
|
2006-10-12 20:47:50 +04:00
|
|
|
for (i = 0;
|
|
|
|
(i < channel->nservers) && (sockindex < ARES_GETSOCK_MAXNUM);
|
|
|
|
i++)
|
2005-12-22 18:27:41 +03:00
|
|
|
{
|
|
|
|
server = &channel->servers[i];
|
2007-09-29 23:26:59 +04:00
|
|
|
/* We only need to register interest in UDP sockets if we have
|
|
|
|
* outstanding queries.
|
|
|
|
*/
|
|
|
|
if (active_queries && server->udp_socket != ARES_SOCKET_BAD)
|
2005-12-22 18:27:41 +03:00
|
|
|
{
|
|
|
|
if(sockindex >= numsocks)
|
|
|
|
break;
|
|
|
|
socks[sockindex] = server->udp_socket;
|
|
|
|
bitmap |= ARES_GETSOCK_READABLE(setbits, sockindex);
|
|
|
|
sockindex++;
|
|
|
|
}
|
2007-09-29 23:26:59 +04:00
|
|
|
/* We always register for TCP events, because we want to know
|
|
|
|
* when the other side closes the connection, so we don't waste
|
|
|
|
* time trying to use a broken connection.
|
|
|
|
*/
|
2005-12-22 18:27:41 +03:00
|
|
|
if (server->tcp_socket != ARES_SOCKET_BAD)
|
|
|
|
{
|
|
|
|
if(sockindex >= numsocks)
|
|
|
|
break;
|
|
|
|
socks[sockindex] = server->tcp_socket;
|
|
|
|
bitmap |= ARES_GETSOCK_READABLE(setbits, sockindex);
|
|
|
|
|
2007-09-29 23:26:59 +04:00
|
|
|
if (server->qhead && active_queries)
|
2005-12-22 18:27:41 +03:00
|
|
|
/* then the tcp socket is also writable! */
|
2006-10-12 20:47:50 +04:00
|
|
|
bitmap |= ARES_GETSOCK_WRITABLE(setbits, sockindex);
|
2005-12-22 18:27:41 +03:00
|
|
|
|
2006-10-12 20:47:50 +04:00
|
|
|
sockindex++;
|
2005-12-22 18:27:41 +03:00
|
|
|
}
|
|
|
|
}
|
2006-08-03 22:20:45 +04:00
|
|
|
return bitmap;
|
2005-12-22 18:27:41 +03:00
|
|
|
}
|