aboutsummaryrefslogtreecommitdiff
path: root/ares__close_sockets.c
diff options
context:
space:
mode:
authorGilad Arnold <garnold@google.com>2015-07-17 00:23:30 -0700
committerGilad Arnold <garnold@google.com>2015-07-17 16:18:06 -0700
commit968bf19396ad404e89420f5d67900fce13f4186c (patch)
treedf6210e63ac2b96d6e638cb288a07776d1373cf5 /ares__close_sockets.c
parent9ade30bfaf6d122f95d862c10092b1f817b8f119 (diff)
downloadc-ares-968bf19396ad404e89420f5d67900fce13f4186c.tar.gz
Initial c-ares-1.7.5 distribution.
Includes NOTICE and MODULE_LICENSE_MIT files. Omitted: - m4/ - vc/ - *.pdf - *.[13] - Makefile.{Watcom,dj,m32,msvc,netware} Bug: 22545809
Diffstat (limited to 'ares__close_sockets.c')
-rw-r--r--ares__close_sockets.c66
1 files changed, 66 insertions, 0 deletions
diff --git a/ares__close_sockets.c b/ares__close_sockets.c
new file mode 100644
index 0000000..5d391a9
--- /dev/null
+++ b/ares__close_sockets.c
@@ -0,0 +1,66 @@
+
+/* Copyright 1998 by the Massachusetts Institute of Technology.
+ *
+ * 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 "ares_setup.h"
+
+#include <stdlib.h>
+#ifdef HAVE_UNISTD_H
+#include <unistd.h>
+#endif
+
+#include "ares.h"
+#include "ares_private.h"
+
+void ares__close_sockets(ares_channel channel, struct server_state *server)
+{
+ struct send_request *sendreq;
+
+ /* Free all pending output buffers. */
+ while (server->qhead)
+ {
+ /* Advance server->qhead; pull out query as we go. */
+ sendreq = server->qhead;
+ server->qhead = sendreq->next;
+ if (sendreq->data_storage != NULL)
+ free(sendreq->data_storage);
+ free(sendreq);
+ }
+ server->qtail = NULL;
+
+ /* Reset any existing input buffer. */
+ if (server->tcp_buffer)
+ free(server->tcp_buffer);
+ server->tcp_buffer = NULL;
+ server->tcp_lenbuf_pos = 0;
+
+ /* Reset brokenness */
+ server->is_broken = 0;
+
+ /* Close the TCP and UDP sockets. */
+ if (server->tcp_socket != ARES_SOCKET_BAD)
+ {
+ SOCK_STATE_CALLBACK(channel, server->tcp_socket, 0, 0);
+ sclose(server->tcp_socket);
+ server->tcp_socket = ARES_SOCKET_BAD;
+ server->tcp_connection_generation = ++channel->tcp_connection_generation;
+ }
+ if (server->udp_socket != ARES_SOCKET_BAD)
+ {
+ SOCK_STATE_CALLBACK(channel, server->udp_socket, 0, 0);
+ sclose(server->udp_socket);
+ server->udp_socket = ARES_SOCKET_BAD;
+ }
+}