Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/external/mpl/bind/dist/lib/isc/unix cleanup unused stuff now...



details:   https://anonhg.NetBSD.org/src/rev/28ace656feb7
branches:  trunk
changeset: 996903:28ace656feb7
user:      christos <christos%NetBSD.org@localhost>
date:      Wed Feb 13 01:16:30 2019 +0000

description:
cleanup unused stuff now that we execute directly and not in a separate task.

diffstat:

 external/mpl/bind/dist/lib/isc/unix/socket.c |  167 ++++----------------------
 1 files changed, 28 insertions(+), 139 deletions(-)

diffs (truncated from 302 to 300 lines):

diff -r eed78141b818 -r 28ace656feb7 external/mpl/bind/dist/lib/isc/unix/socket.c
--- a/external/mpl/bind/dist/lib/isc/unix/socket.c      Tue Feb 12 21:41:38 2019 +0000
+++ b/external/mpl/bind/dist/lib/isc/unix/socket.c      Wed Feb 13 01:16:30 2019 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: socket.c,v 1.6 2019/02/12 02:38:55 christos Exp $      */
+/*     $NetBSD: socket.c,v 1.7 2019/02/13 01:16:30 christos Exp $      */
 
 /*
  * Copyright (C) Internet Systems Consortium, Inc. ("ISC")
@@ -351,14 +351,6 @@
        char                            name[16];
        void *                          tag;
 
-       /*
-        * Internal events.  Posted when a descriptor is readable or
-        * writable.  These are statically allocated and never freed.
-        * They will be set to non-purgable before use.
-        */
-       intev_t                 readable_ev;
-       intev_t                 writable_ev;
-
        ISC_LIST(isc_socketevent_t)             send_list;
        ISC_LIST(isc_socketevent_t)             recv_list;
        ISC_LIST(isc_socket_newconnev_t)        accept_list;
@@ -366,9 +358,7 @@
 
        isc_sockaddr_t          peer_address;       /* remote address */
 
-       unsigned int            pending_recv : 1,
-                               pending_send : 1,
-                               listener : 1,       /* listener socket */
+       unsigned int            listener : 1,       /* listener socket */
                                connected : 1,
                                connecting : 1,     /* connect pending */
                                bound : 1,          /* bound to local addr */
@@ -380,10 +370,10 @@
        unsigned char           overflow; /* used for MSG_TRUNC fake */
 #endif
 
-        void                    *fdwatcharg;    
-        isc_sockfdwatch_t       fdwatchcb;
-        int                     fdwatchflags;
-        isc_task_t              *fdwatchtask;
+       void                    *fdwatcharg;
+       isc_sockfdwatch_t       fdwatchcb;
+       int                     fdwatchflags;
+       isc_task_t              *fdwatchtask;
        unsigned int            dscp;
 };
 
@@ -474,8 +464,8 @@
 static void internal_connect(isc__socket_t *);
 static void internal_recv(isc__socket_t *);
 static void internal_send(isc__socket_t *);
-static void internal_fdwatch_write(isc_task_t *, isc_event_t *);
-static void internal_fdwatch_read(isc_task_t *, isc_event_t *);
+static void internal_fdwatch_write(isc__socket_t *);
+static void internal_fdwatch_read(isc__socket_t *);
 static void process_cmsg(isc__socket_t *, struct msghdr *, isc_socketevent_t *);
 static void build_msghdr_send(isc__socket_t *, char *, isc_socketevent_t *,
                              struct msghdr *, struct iovec *, size_t *);
@@ -1962,8 +1952,6 @@
        ISC_LIST_INIT(sock->accept_list);
        ISC_LIST_INIT(sock->connect_list);
        sock->listener = 0;
-       sock->pending_recv = 0;
-       sock->pending_send = 0;
        sock->connected = 0;
        sock->connecting = 0;
        sock->bound = 0;
@@ -1974,16 +1962,6 @@
         */
        isc_mutex_init(&sock->lock);
 
-       /*
-        * Initialize readable and writable events.
-        */
-       ISC_EVENT_INIT(&sock->readable_ev, sizeof(intev_t),
-                      ISC_EVENTATTR_NOPURGE, NULL, ISC_SOCKEVENT_INTR,
-                      NULL, sock, sock, NULL, NULL);
-       ISC_EVENT_INIT(&sock->writable_ev, sizeof(intev_t),
-                      ISC_EVENTATTR_NOPURGE, NULL, ISC_SOCKEVENT_INTW,
-                      NULL, sock, sock, NULL, NULL);
-
        sock->common.magic = ISCAPI_SOCKET_MAGIC;
        sock->common.impmagic = SOCKET_MAGIC;
        *socketp = sock;
@@ -2005,8 +1983,6 @@
        INSIST(VALID_SOCKET(sock));
        INSIST(isc_refcount_current(&sock->references) == 0);
        INSIST(!sock->connecting);
-       INSIST(!sock->pending_recv);
-       INSIST(!sock->pending_send);
        INSIST(ISC_LIST_EMPTY(sock->recv_list));
        INSIST(ISC_LIST_EMPTY(sock->send_list));
        INSIST(ISC_LIST_EMPTY(sock->accept_list));
@@ -2820,8 +2796,6 @@
        REQUIRE(sock->fd >= 0 && sock->fd < (int)sock->manager->maxsocks);
 
        INSIST(!sock->connecting);
-       INSIST(!sock->pending_recv);
-       INSIST(!sock->pending_send);
        INSIST(ISC_LIST_EMPTY(sock->recv_list));
        INSIST(ISC_LIST_EMPTY(sock->send_list));
        INSIST(ISC_LIST_EMPTY(sock->accept_list));
@@ -2849,64 +2823,22 @@
        return (ISC_R_SUCCESS);
 }
 
-/*
- * I/O is possible on a given socket.  Schedule an event to this task that
- * will call an internal function to do the I/O.  This will charge the
- * task with the I/O operation and let our select loop handler get back
- * to doing something real as fast as possible.
- *
- * The socket and manager must be locked before calling this function.
- */
 static void
 dispatch_recv(isc__socket_t *sock) {
-       intev_t *iev;
-       isc_task_t *sender;
-
        if (sock->type != isc_sockettype_fdwatch) {
                internal_recv(sock);
-               return;
-       }
-
-       LOCK(&sock->lock);
-       INSIST(!sock->pending_recv);
-
-       sender = sock->fdwatchtask;
-       sock->pending_recv = 1;
-       iev = &sock->readable_ev;
-
-       isc_refcount_increment(&sock->references);
-       iev->ev_sender = sock;
-       iev->ev_action = internal_fdwatch_read;
-       iev->ev_arg = sock;
-       UNLOCK(&sock->lock);
-       internal_fdwatch_read(sender, iev);
+       } else {
+               internal_fdwatch_read(sock);
+       }
 }
 
 static void
 dispatch_send(isc__socket_t *sock) {
-       intev_t *iev;
-       isc_task_t *sender;
-
        if (sock->type != isc_sockettype_fdwatch) {
                internal_send(sock);
-               return;
-       }
-
-       LOCK(&sock->lock);
-
-       INSIST(!sock->pending_send);
-
-       sender = sock->fdwatchtask;
-       sock->pending_send = 1;
-       iev = &sock->writable_ev;
-
-       isc_refcount_increment(&sock->references);
-       iev->ev_sender = sock;
-       iev->ev_action = internal_fdwatch_write;
-       iev->ev_arg = sock;
-
-       UNLOCK(&sock->lock);
-       internal_fdwatch_write(sender, iev);
+       } else {
+               internal_fdwatch_write(sock);
+       }
 }
 
 /*
@@ -3347,32 +3279,21 @@
 }
 
 static void
-internal_fdwatch_write(isc_task_t *me, isc_event_t *ev) {
-       isc__socket_t *sock;
+internal_fdwatch_write(isc__socket_t *sock)
+{
        int more_data;
 
-       INSIST(ev->ev_type == ISC_SOCKEVENT_INTW);
-
-       /*
-        * Find out what socket this is and lock it.
-        */
-       sock = (isc__socket_t *)ev->ev_sender;
        INSIST(VALID_SOCKET(sock));
 
        LOCK(&sock->lock);
-       socket_log(sock, NULL, IOEVENT,
-                  isc_msgcat, ISC_MSGSET_SOCKET, ISC_MSG_INTERNALSEND,
-                  "internal_fdwatch_write: task %p got event %p", me, ev);
-
-       INSIST(sock->pending_send == 1);
-
+       isc_refcount_increment(&sock->references);
        UNLOCK(&sock->lock);
-       more_data = (sock->fdwatchcb)(me, (isc_socket_t *)sock,
+
+       more_data = (sock->fdwatchcb)(sock->fdwatchtask, (isc_socket_t *)sock,
                                      sock->fdwatcharg, ISC_SOCKFDWATCH_WRITE);
+
        LOCK(&sock->lock);
 
-       sock->pending_send = 0;
-
        if (isc_refcount_decrement(&sock->references) == 0) {
                UNLOCK(&sock->lock);
                destroy(&sock);
@@ -3387,31 +3308,21 @@
 }
 
 static void
-internal_fdwatch_read(isc_task_t *me, isc_event_t *ev) {
-       isc__socket_t *sock;
+internal_fdwatch_read(isc__socket_t *sock)
+{
        int more_data;
 
-       INSIST(ev->ev_type == ISC_SOCKEVENT_INTR);
-
-       /*
-        * Find out what socket this is and lock it.
-        */
-       sock = (isc__socket_t *)ev->ev_sender;
        INSIST(VALID_SOCKET(sock));
 
        LOCK(&sock->lock);
-       socket_log(sock, NULL, IOEVENT,
-                  isc_msgcat, ISC_MSGSET_SOCKET, ISC_MSG_INTERNALRECV,
-                  "internal_fdwatch_read: task %p got event %p", me, ev);
-
-       INSIST(sock->pending_recv == 1);
-
+       isc_refcount_increment(&sock->references);
        UNLOCK(&sock->lock);
-       more_data = (sock->fdwatchcb)(me, (isc_socket_t *)sock,
+
+       more_data = (sock->fdwatchcb)(sock->fdwatchtask, (isc_socket_t *)sock,
                                      sock->fdwatcharg, ISC_SOCKFDWATCH_READ);
+
        LOCK(&sock->lock);
 
-       sock->pending_recv = 0;
        if (isc_refcount_decrement(&sock->references) == 0) {
                UNLOCK(&sock->lock);
                destroy(&sock);
@@ -5759,14 +5670,6 @@
                }
 
                TRY0(xmlTextWriterStartElement(writer, ISC_XMLCHAR "states"));
-               if (sock->pending_recv)
-                       TRY0(xmlTextWriterWriteElement(writer,
-                                               ISC_XMLCHAR "state",
-                                               ISC_XMLCHAR "pending-receive"));
-               if (sock->pending_send)
-                       TRY0(xmlTextWriterWriteElement(writer,
-                                                 ISC_XMLCHAR "state",
-                                                 ISC_XMLCHAR "pending-send"));
                if (sock->listener)
                        TRY0(xmlTextWriterWriteElement(writer,
                                                       ISC_XMLCHAR "state",
@@ -5875,18 +5778,6 @@
                CHECKMEM(states);
                json_object_object_add(entry, "states", states);
 
-               if (sock->pending_recv) {
-                       obj = json_object_new_string("pending-receive");
-                       CHECKMEM(obj);
-                       json_object_array_add(states, obj);
-               }
-
-               if (sock->pending_send) {
-                       obj = json_object_new_string("pending-send");
-                       CHECKMEM(obj);
-                       json_object_array_add(states, obj);
-               }
-
                if (sock->listener) {
                        obj = json_object_new_string("listener");
                        CHECKMEM(obj);
@@ -6042,12 +5933,10 @@
 
        if ((flags & (ISC_SOCKFDWATCH_READ | ISC_SOCKFDWATCH_WRITE)) != 0) {
                LOCK(&sock->lock);
-               if (((flags & ISC_SOCKFDWATCH_READ) != 0) &&
-                   !sock->pending_recv)
+               if ((flags & ISC_SOCKFDWATCH_READ) != 0)
                        select_poke(sock->manager, sock->threadid, sock->fd,
                                    SELECT_POKE_READ);
-               if (((flags & ISC_SOCKFDWATCH_WRITE) != 0) &&
-                   !sock->pending_send)
+               if ((flags & ISC_SOCKFDWATCH_WRITE) != 0)
                        select_poke(sock->manager, sock->threadid, sock->fd,



Home | Main Index | Thread Index | Old Index