diff options
author | neilbrown <neilbrown> | 2002-09-02 02:31:12 +0000 |
---|---|---|
committer | neilbrown <neilbrown> | 2002-09-02 02:31:12 +0000 |
commit | 55ce21003ee0fb12fe5ef70909cdc8ce00b803e4 (patch) | |
tree | 75151711c32ae998dc51d80256d232cc5e12df75 /utils/statd/statd.c | |
parent | 9bea78d8f36cd5ab75d18e32224f0b90a635128c (diff) | |
download | nfs-utils-55ce21003ee0fb12fe5ef70909cdc8ce00b803e4.tar.gz nfs-utils-55ce21003ee0fb12fe5ef70909cdc8ce00b803e4.tar.xz nfs-utils-55ce21003ee0fb12fe5ef70909cdc8ce00b803e4.zip |
-N for statd
Diffstat (limited to 'utils/statd/statd.c')
-rw-r--r-- | utils/statd/statd.c | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/utils/statd/statd.c b/utils/statd/statd.c index 3a6ed61..b1e7304 100644 --- a/utils/statd/statd.c +++ b/utils/statd/statd.c @@ -55,6 +55,7 @@ static struct option longopts[] = { "port", 1, 0, 'p' }, { "name", 1, 0, 'n' }, { "state-directory-path", 1, 0, 'P' }, + { "notify-mode", 0, 0, 'N' }, { NULL, 0, 0, 0 } }; @@ -112,11 +113,11 @@ static void log_modes(void) strcat(buf,"No-Daemon "); if (run_mode & MODE_LOG_STDERR) strcat(buf,"Log-STDERR "); - /* future: IP aliasing + if (run_mode & MODE_NOTIFY_ONLY) { strcat(buf,"Notify-Only "); - } */ + } log(L_WARNING,buf); /* future: IP aliasing if (run_mode & MODE_NOTIFY_ONLY) @@ -141,6 +142,7 @@ usage() fprintf(stderr," -V, -v, --version Display version information and exit.\n"); fprintf(stderr," -n, --name Specify a local hostname.\n"); fprintf(stderr," -P State directory path.\n"); + fprintf(stderr," -N Run in notify only mode.\n"); } /* @@ -174,7 +176,7 @@ int main (int argc, char **argv) MY_NAME = NULL; /* Process command line switches */ - while ((arg = getopt_long(argc, argv, "h?vVFdn:p:o:P:", longopts, NULL)) != EOF) { + while ((arg = getopt_long(argc, argv, "h?vVFNdn:p:o:P:", longopts, NULL)) != EOF) { switch (arg) { case 'V': /* Version */ case 'v': @@ -183,6 +185,9 @@ int main (int argc, char **argv) case 'F': /* Foreground/nodaemon mode */ run_mode |= MODE_NODAEMON; break; + case 'N': + run_mode |= MODE_NOTIFY_ONLY; + break; case 'd': /* No daemon only - log to stderr */ run_mode |= MODE_LOG_STDERR; break; @@ -308,18 +313,19 @@ int main (int argc, char **argv) notify_hosts (); /* Send out notify requests */ ++restart; - /* future: IP aliasing + /* this registers both UDP and TCP services */ if (!(run_mode & MODE_NOTIFY_ONLY)) { rpc_init("statd", SM_PROG, SM_VERS, sm_prog_1, port); - } */ - /* this registers both UDP and TCP services */ - rpc_init("statd", SM_PROG, SM_VERS, sm_prog_1, port); + } /* * Handle incoming requests: SM_NOTIFY socket requests, as * well as callbacks from lockd. */ my_svc_run(); /* I rolled my own, Olaf made it better... */ + + if ((run_mode & MODE_NOTIFY_ONLY)) + break; } return 0; } |