]> git.decadent.org.uk Git - nfs-utils.git/commitdiff
See Changelog nfs-utils-1-1-0-pre7
authorneilbrown <neilbrown>
Wed, 2 Jul 2003 06:51:21 +0000 (06:51 +0000)
committerneilbrown <neilbrown>
Wed, 2 Jul 2003 06:51:21 +0000 (06:51 +0000)
ChangeLog
utils/mountd/mountd.c
utils/mountd/mountd.man
utils/nfsstat/nfsstat.c

index 7c22de77ec10f8fdb7b4b4d5fe2ca68c0fdf6c99..0f490c1a04fd7f85ab27f7513d74a0e47a0c7eee 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,12 @@
+2003-07-02 NeilBrown <neilb@cse.unsw.edu.au>
+       Steve Dickson <SteveD@redhat.com>
+
+       * utils/mountd/mountd.man: Add valid kinds of debugging.
+       * utils/mountd/mountd.c(main): ignore SIGPIPE
+       * utils/nfsstat/nfsstat.c: fine-tune printing of warning so
+       we don't get warnings about unavailable stats that weren't asked
+       for.
+       
 2003-06-24 NeilBrown <neilb@cse.unsw.edu.au>
 
        * support/nfs/nfsexport.c(exp_unexp): When unexporting filesystems
index 3769c924d2d22a0e973e19a202d2d31833f40057..953891df30f5deac6b8111f62242220d79672dde 100644 (file)
@@ -520,6 +520,7 @@ main(int argc, char **argv)
        sigaction(SIGHUP, &sa, NULL);
        sigaction(SIGINT, &sa, NULL);
        sigaction(SIGTERM, &sa, NULL);
+       sigaction(SIGPIPE, &sa, NULL);
        /* WARNING: the following works on Linux and SysV, but not BSD! */
        sigaction(SIGCHLD, &sa, NULL);
 
index f68dd17f9ed4721b0214fd17659f71521834e9d7..77f4e266563508952126b36cae500aecf2a8d328 100644 (file)
@@ -56,7 +56,7 @@ a stale entry will remain in
 .SH OPTIONS
 .TP
 .B \-d kind " or " \-\-debug kind
-Turn on debugging for kind.
+Turn on debugging. Valid kinds are: all, auth, call, general and parse.
 .TP
 .B \-F " or " \-\-foreground
 Run in foreground (do not daemonize)
index b26b3b8a04acacad40a1a6d89311e895d615abc1..55c40967f4b9b606a48c05d21e435322e52d8355 100644 (file)
@@ -124,6 +124,8 @@ main(int argc, char **argv)
        int             opt_all = 0,
                        opt_srv = 0,
                        opt_clt = 0,
+                       srv_info = 0,
+                       clt_info = 0,
                        opt_prt = 0;
        int             c;
 
@@ -184,9 +186,25 @@ main(int argc, char **argv)
                        "server.\n");
        }
 
-       if ((opt_srv && !parse_statfile(NFSSVCSTAT, svcinfo))
-        || (opt_clt && !parse_statfile(NFSCLTSTAT, cltinfo)))
-               return 2;
+       if (opt_srv) {
+               srv_info = parse_statfile(NFSSVCSTAT, svcinfo);
+               if (srv_info == 0 && opt_clt == 0) {
+                       fprintf(stderr, "Warning: No Server Stats (%s: %m).\n", NFSSVCSTAT);
+                       return 2;
+               }
+               if (srv_info == 0)
+                       opt_srv = 0;
+       }
+
+       if (opt_clt) {
+               clt_info = parse_statfile(NFSCLTSTAT, cltinfo);
+               if (opt_srv == 0 && clt_info == 0) {
+                       fprintf(stderr, "Warning: No Client Stats (%s: %m).\n", NFSCLTSTAT);
+                       return 2;
+               }
+               if (clt_info == 0)
+                       opt_clt = 0;
+       }
 
        if (opt_srv) {
                if (opt_prt & PRNT_NET) {
@@ -340,8 +358,8 @@ parse_statfile(const char *name, struct statinfo *statp)
         * be a fatal error -- it usually means the module isn't loaded.
         */
        if ((fp = fopen(name, "r")) == NULL) {
-               fprintf(stderr, "Warning: %s: %m\n", name);
-               return 1;
+               // fprintf(stderr, "Warning: %s: %m\n", name);
+               return 0;
        }
 
        while (fgets(buffer, sizeof(buffer), fp) != NULL) {