From 3482b1145c2c9a39f1dcaabc32e36eb234b91447 Mon Sep 17 00:00:00 2001 From: Neil Brown Date: Tue, 20 Mar 2007 10:14:44 +1100 Subject: [PATCH] statd - delay drop-privs until sockets have been setup. Registering sockets with portmap might require root privs, so don't drop privs until that has been done. --- utils/statd/statd.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/utils/statd/statd.c b/utils/statd/statd.c index 17e2947..157de85 100644 --- a/utils/statd/statd.c +++ b/utils/statd/statd.c @@ -251,6 +251,7 @@ int main (int argc, char **argv) int arg; int port = 0, out_port = 0; struct rlimit rlim; + int once = 1; int pipefds[2] = { -1, -1}; char status; @@ -474,7 +475,6 @@ int main (int argc, char **argv) waitpid(pid, NULL, 0); } - drop_privs(); for (;;) { pmap_unset (SM_PROG, SM_VERS); @@ -490,6 +490,10 @@ int main (int argc, char **argv) /* this registers both UDP and TCP services */ rpc_init("statd", SM_PROG, SM_VERS, sm_prog_1, port); + if (once) { + once = 0; + drop_privs(); + } /* * Handle incoming requests: SM_NOTIFY socket requests, as * well as callbacks from lockd. -- 2.39.2