Source-Changes-HG archive

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

[src/trunk]: src/lib/libc/rpc check for errors and recover instead of core-du...



details:   https://anonhg.NetBSD.org/src/rev/46cc2a0e7f06
branches:  trunk
changeset: 341467:46cc2a0e7f06
user:      christos <christos%NetBSD.org@localhost>
date:      Sat Nov 07 17:34:33 2015 +0000

description:
check for errors and recover instead of core-dumping.

diffstat:

 lib/libc/rpc/svc.c     |  13 ++++++++-----
 lib/libc/rpc/svc_run.c |  20 +++++++++++++-------
 lib/libc/rpc/svc_vc.c  |  23 ++++++++++++++++-------
 3 files changed, 37 insertions(+), 19 deletions(-)

diffs (172 lines):

diff -r b151aca82473 -r 46cc2a0e7f06 lib/libc/rpc/svc.c
--- a/lib/libc/rpc/svc.c        Sat Nov 07 16:58:24 2015 +0000
+++ b/lib/libc/rpc/svc.c        Sat Nov 07 17:34:33 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: svc.c,v 1.35 2015/11/06 19:34:13 christos Exp $        */
+/*     $NetBSD: svc.c,v 1.36 2015/11/07 17:34:33 christos Exp $        */
 
 /*
  * Copyright (c) 2010, Oracle America, Inc.
@@ -37,7 +37,7 @@
 static char *sccsid = "@(#)svc.c 1.44 88/02/08 Copyr 1984 Sun Micro";
 static char *sccsid = "@(#)svc.c       2.4 88/08/11 4.0 RPCSRC";
 #else
-__RCSID("$NetBSD: svc.c,v 1.35 2015/11/06 19:34:13 christos Exp $");
+__RCSID("$NetBSD: svc.c,v 1.36 2015/11/07 17:34:33 christos Exp $");
 #endif
 #endif
 
@@ -179,7 +179,8 @@
 
        __svc_xports[sock] = xprt;
        if (sock != -1) {
-               svc_fdset_set(sock);
+               if (svc_fdset_set(sock) == -1)
+                       return FALSE;
        }
        rwlock_unlock(&svc_fd_lock);
        return (TRUE);
@@ -222,7 +223,7 @@
        if (sock == -1)
                goto out;
        fdmax = svc_fdset_getmax();
-       if (sock < *fdmax)
+       if (fdmax == NULL || sock < *fdmax)
                goto clr;
 
        for ((*fdmax)--; *fdmax >= 0; (*fdmax)--)
@@ -634,6 +635,8 @@
 svc_getreq(int rdfds)
 {
        fd_set *readfds = svc_fdset_copy(NULL);
+       if (readfds == NULL)
+               return;
 
        readfds->fds_bits[0] = (unsigned int)rdfds;
        svc_getreqset(readfds);
@@ -771,7 +774,7 @@
                         *      via someone select()ing from svc_fdset or
                         *      pollts()ing from svc_pollset[].  Thus it's safe
                         *      to handle the POLLNVAL event by simply turning
-                        *      the corresponding bit off in svc_fdset.  The
+                        *      the corresponding bit off in the fdset.  The
                         *      svc_pollset[] array is derived from svc_fdset
                         *      and so will also be updated eventually.
                         *
diff -r b151aca82473 -r 46cc2a0e7f06 lib/libc/rpc/svc_run.c
--- a/lib/libc/rpc/svc_run.c    Sat Nov 07 16:58:24 2015 +0000
+++ b/lib/libc/rpc/svc_run.c    Sat Nov 07 17:34:33 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: svc_run.c,v 1.23 2015/11/06 19:34:13 christos Exp $    */
+/*     $NetBSD: svc_run.c,v 1.24 2015/11/07 17:34:33 christos Exp $    */
 
 /*
  * Copyright (c) 2010, Oracle America, Inc.
@@ -37,7 +37,7 @@
 static char *sccsid = "@(#)svc_run.c 1.1 87/10/13 Copyr 1984 Sun Micro";
 static char *sccsid = "@(#)svc_run.c   2.1 88/07/29 4.0 RPCSRC";
 #else
-__RCSID("$NetBSD: svc_run.c,v 1.23 2015/11/06 19:34:13 christos Exp $");
+__RCSID("$NetBSD: svc_run.c,v 1.24 2015/11/07 17:34:33 christos Exp $");
 #endif
 #endif
 
@@ -69,7 +69,7 @@
 {
        fd_set *readfds, *cleanfds;
        struct timeval timeout;
-       int maxfd, fdsize;
+       int *maxfd, fdsize;
 #ifndef RUMP_RPC               
        int probs = 0;
 #endif
@@ -92,9 +92,13 @@
                        free(cleanfds);
                        cleanfds = svc_fdset_copy(svc_fdset_get());
                }
-               maxfd = *svc_fdset_getmax();
+               maxfd = svc_fdset_getmax();
+               if (maxfd == NULL) {
+                       warn("can't get maxfd");
+                       continue;
+               }
                rwlock_unlock(&svc_fd_lock);
-               switch (select(maxfd + 1, readfds, NULL, NULL, &timeout)) {
+               switch (select(*maxfd + 1, readfds, NULL, NULL, &timeout)) {
                case -1:
 #ifndef RUMP_RPC               
                        if ((errno == EINTR || errno == EBADF) && probs < 100) {
@@ -108,10 +112,12 @@
                        warn("%s: select failed", __func__);
                        goto out;
                case 0:
-                       __svc_clean_idle(cleanfds, 30, FALSE);
+                       if (cleanfds)
+                               __svc_clean_idle(cleanfds, 30, FALSE);
                        continue;
                default:
-                       svc_getreqset2(readfds, fdsize);
+                       if (readfds)
+                               svc_getreqset2(readfds, fdsize);
 #ifndef RUMP_RPC
                        probs = 0;
 #endif
diff -r b151aca82473 -r 46cc2a0e7f06 lib/libc/rpc/svc_vc.c
--- a/lib/libc/rpc/svc_vc.c     Sat Nov 07 16:58:24 2015 +0000
+++ b/lib/libc/rpc/svc_vc.c     Sat Nov 07 17:34:33 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: svc_vc.c,v 1.31 2015/11/06 19:34:13 christos Exp $     */
+/*     $NetBSD: svc_vc.c,v 1.32 2015/11/07 17:34:33 christos Exp $     */
 
 /*
  * Copyright (c) 2010, Oracle America, Inc.
@@ -37,7 +37,7 @@
 static char *sccsid = "@(#)svc_tcp.c 1.21 87/08/11 Copyr 1984 Sun Micro";
 static char *sccsid = "@(#)svc_tcp.c   2.2 88/08/01 4.0 RPCSRC";
 #else
-__RCSID("$NetBSD: svc_vc.c,v 1.31 2015/11/06 19:34:13 christos Exp $");
+__RCSID("$NetBSD: svc_vc.c,v 1.32 2015/11/07 17:34:33 christos Exp $");
 #endif
 #endif
 
@@ -329,7 +329,9 @@
                 */
                if (errno == EMFILE || errno == ENFILE) {
                        fd_set *cleanfds = svc_fdset_copy(svc_fdset_get());
-                       int rv = __svc_clean_idle(cleanfds, 0, FALSE);
+                       int rv = 0;
+                       if (cleanfds)
+                               rv = __svc_clean_idle(cleanfds, 0, FALSE);
                        free(cleanfds);
                        if (rv)
                                goto again;
@@ -761,7 +763,7 @@
 bool_t
 __svc_clean_idle(fd_set *fds, int timeout, bool_t cleanblock)
 {
-       int i, ncleaned, fdmax;
+       int i, ncleaned, *fdmax;
        SVCXPRT *xprt, *least_active;
        struct timeval tv, tdiff, tmax;
        struct cf_conn *cd;
@@ -770,10 +772,17 @@
        tmax.tv_sec = tmax.tv_usec = 0;
        least_active = NULL;
        rwlock_wrlock(&svc_fd_lock);
-       fdmax = *svc_fdset_getmax();
-       for (i = ncleaned = 0; i <= fdmax; i++) {
-               if (!svc_fdset_isset(i))
+       fdmax = svc_fdset_getmax();
+       if (fdmax == NULL)
+               return FALSE;
+       for (i = ncleaned = 0; i <= *fdmax; i++) {
+               switch (svc_fdset_isset(i)) {
+               case 0:
+               case -1:
                        continue;
+               default:
+                       break;
+               }
 
                xprt = __svc_xports[i];
                if (xprt == NULL || xprt->xp_ops == NULL ||



Home | Main Index | Thread Index | Old Index