From: Todd C. Miller Date: Mon, 6 Mar 2017 20:05:17 +0000 (-0700) Subject: Prevent sudo from receiving SIGTTOU when it tries to restore the X-Git-Tag: SUDO_1_8_20^2~85 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=2f074d33abd734fce740e464ec4df546d2bdc013;p=sudo Prevent sudo from receiving SIGTTOU when it tries to restore the controlling terminal. There appears to be a race with the shell (bash) which we may lose. --- diff --git a/src/exec_nopty.c b/src/exec_nopty.c index c72eb3159..b6826ef70 100644 --- a/src/exec_nopty.c +++ b/src/exec_nopty.c @@ -391,11 +391,21 @@ dispatch_signal(struct exec_closure_nopty *ec, int signo, char *signame) } if (saved_pgrp != -1) { /* - * Restore command's process group if different. - * Otherwise, we cannot resume some shells. + * Restore foreground process group, if different. + * Otherwise, we cannot resume some shells (pdksh). + * + * There appears to be a race with shells that do restore + * the controlling group. Sudo can receive SIGTTOU + * if the shell has already changed the controlling tty. */ - if (saved_pgrp != ppgrp) + if (saved_pgrp != ppgrp) { + sigset_t set, oset; + sigemptyset(&set); + sigaddset(&set, SIGTTOU); + sigprocmask(SIG_BLOCK, &set, &oset); (void)tcsetpgrp(fd, saved_pgrp); + sigprocmask(SIG_SETMASK, &oset, NULL); + } close(fd); } } else {