aboutsummaryrefslogtreecommitdiff
path: root/debianutils/start_stop_daemon.c
diff options
context:
space:
mode:
authorRon Yorston <rmy@pobox.com>2012-03-23 11:13:23 +0000
committerRon Yorston <rmy@pobox.com>2012-03-23 11:13:23 +0000
commit40514a0309939f2446f0d4ed9600cad5de396e7f (patch)
tree0f5f4a57d4bb7893418b5bb11d482858eb17ba8b /debianutils/start_stop_daemon.c
parent9db164d6e39050d09f38288c6045cd2a2cbf6d63 (diff)
parentc0cae52662ccced9df19f19ec94238d1b1e3bd71 (diff)
downloadbusybox-w32-40514a0309939f2446f0d4ed9600cad5de396e7f.tar.gz
busybox-w32-40514a0309939f2446f0d4ed9600cad5de396e7f.tar.bz2
busybox-w32-40514a0309939f2446f0d4ed9600cad5de396e7f.zip
Merge commit 'c0cae52662ccced9df19f19ec94238d1b1e3bd71' into merge
Conflicts: Makefile.flags scripts/basic/fixdep.c
Diffstat (limited to 'debianutils/start_stop_daemon.c')
-rw-r--r--debianutils/start_stop_daemon.c12
1 files changed, 10 insertions, 2 deletions
diff --git a/debianutils/start_stop_daemon.c b/debianutils/start_stop_daemon.c
index bc61959d2..02609c04f 100644
--- a/debianutils/start_stop_daemon.c
+++ b/debianutils/start_stop_daemon.c
@@ -502,8 +502,16 @@ int start_stop_daemon_main(int argc UNUSED_PARAM, char **argv)
502 if (opt & OPT_c) { 502 if (opt & OPT_c) {
503 struct bb_uidgid_t ugid = { -1, -1 }; 503 struct bb_uidgid_t ugid = { -1, -1 };
504 parse_chown_usergroup_or_die(&ugid, chuid); 504 parse_chown_usergroup_or_die(&ugid, chuid);
505 if (ugid.gid != (gid_t) -1) xsetgid(ugid.gid); 505 if (ugid.uid != (uid_t) -1) {
506 if (ugid.uid != (uid_t) -1) xsetuid(ugid.uid); 506 struct passwd *pw = xgetpwuid(ugid.uid);
507 if (ugid.gid != (gid_t) -1)
508 pw->pw_gid = ugid.gid;
509 /* initgroups, setgid, setuid: */
510 change_identity(pw);
511 } else if (ugid.gid != (gid_t) -1) {
512 xsetgid(ugid.gid);
513 setgroups(1, &ugid.gid);
514 }
507 } 515 }
508#if ENABLE_FEATURE_START_STOP_DAEMON_FANCY 516#if ENABLE_FEATURE_START_STOP_DAEMON_FANCY
509 if (opt & OPT_NICELEVEL) { 517 if (opt & OPT_NICELEVEL) {