Source-Changes-HG archive

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

[src/netbsd-2]: src/usr.sbin/rpc.statd Pull up following revision(s) (request...



details:   https://anonhg.NetBSD.org/src/rev/4438b0de550d
branches:  netbsd-2
changeset: 564443:4438b0de550d
user:      riz <riz%NetBSD.org@localhost>
date:      Tue Mar 28 23:20:39 2006 +0000

description:
Pull up following revision(s) (requested by tron in ticket #10400):
        usr.sbin/rpc.statd/statd.c: revision 1.27
Use sigaction(2) to setup automatic disposal of child processes after
daemonizing. This is more portable and avoids zombie "rpc.statd"
processes after an NFS client running e.g. Mac OS X shuts down.
Reviewed by christos@.

diffstat:

 usr.sbin/rpc.statd/statd.c |  15 ++++++++-------
 1 files changed, 8 insertions(+), 7 deletions(-)

diffs (43 lines):

diff -r b02780d52462 -r 4438b0de550d usr.sbin/rpc.statd/statd.c
--- a/usr.sbin/rpc.statd/statd.c        Tue Mar 28 23:11:26 2006 +0000
+++ b/usr.sbin/rpc.statd/statd.c        Tue Mar 28 23:20:39 2006 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: statd.c,v 1.23.4.2 2005/12/14 03:52:38 jmc Exp $       */
+/*     $NetBSD: statd.c,v 1.23.4.3 2006/03/28 23:20:39 riz Exp $       */
 
 /*
  * Copyright (c) 1997 Christos Zoulas. All rights reserved.
@@ -37,7 +37,7 @@
 
 #include <sys/cdefs.h>
 #ifndef lint
-__RCSID("$NetBSD: statd.c,v 1.23.4.2 2005/12/14 03:52:38 jmc Exp $");
+__RCSID("$NetBSD: statd.c,v 1.23.4.3 2006/03/28 23:20:39 riz Exp $");
 #endif
 
 /* main() function for status monitor daemon.  Some of the code in this        */
@@ -101,11 +101,6 @@
        struct sigaction nsa;
        int maxrec = RPC_MAXDATASIZE;
 
-       sigemptyset(&nsa.sa_mask);
-       nsa.sa_flags = SA_NOCLDSTOP|SA_NOCLDWAIT;
-       nsa.sa_handler = SIG_IGN;
-       (void)sigaction(SIGCHLD, &nsa, NULL);
-
        while ((ch = getopt(argc, argv, "d")) != (-1)) {
                switch (ch) {
                case 'd':
@@ -140,6 +135,12 @@
         */
        if (!debug)
                daemon(0, 0);
+
+       sigemptyset(&nsa.sa_mask);
+       nsa.sa_flags = SA_NOCLDSTOP|SA_NOCLDWAIT;
+       nsa.sa_handler = SIG_IGN;
+       (void)sigaction(SIGCHLD, &nsa, NULL);
+
        pidfile(NULL);
        openlog("rpc.statd", 0, LOG_DAEMON);
        if (debug)



Home | Main Index | Thread Index | Old Index