]> git.ipfire.org Git - thirdparty/openssh-portable.git/commitdiff
upstream commit
authordjm@openbsd.org <djm@openbsd.org>
Fri, 29 Apr 2016 08:07:53 +0000 (08:07 +0000)
committerDamien Miller <djm@mindrot.org>
Fri, 29 Apr 2016 08:09:02 +0000 (18:09 +1000)
close ControlPersist background process stderr when not
 in debug mode or when logging to a file or syslog. bz#1988 ok dtucker

Upstream-ID: 4fb726f0fdcb155ad419913cea10dc4afd409d24

log.c
ssh.c

diff --git a/log.c b/log.c
index ad12930e1a4bd8aee417379aaee284b1b9817e12..277afda88f207dc7cda5f67d05440fb4be8679c6 100644 (file)
--- a/log.c
+++ b/log.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: log.c,v 1.46 2015/07/08 19:04:21 markus Exp $ */
+/* $OpenBSD: log.c,v 1.47 2016/04/29 08:07:53 djm Exp $ */
 /*
  * Author: Tatu Ylonen <ylo@cs.hut.fi>
  * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
@@ -342,7 +342,7 @@ log_change_level(LogLevel new_log_level)
 int
 log_is_on_stderr(void)
 {
-       return log_on_stderr;
+       return log_on_stderr && log_stderr_fd == STDERR_FILENO;
 }
 
 /* redirect what would usually get written to stderr to specified file */
diff --git a/ssh.c b/ssh.c
index a999d5079ce6405d4e63f5b4b7f0ada10f3d0c6e..a881ba14c92b097bd59e363a7816979c9451512f 100644 (file)
--- a/ssh.c
+++ b/ssh.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ssh.c,v 1.437 2016/03/07 19:02:43 djm Exp $ */
+/* $OpenBSD: ssh.c,v 1.438 2016/04/29 08:07:53 djm Exp $ */
 /*
  * Author: Tatu Ylonen <ylo@cs.hut.fi>
  * Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
@@ -1395,7 +1395,7 @@ static void
 control_persist_detach(void)
 {
        pid_t pid;
-       int devnull;
+       int devnull, keep_stderr;
 
        debug("%s: backgrounding master process", __func__);
 
@@ -1426,8 +1426,10 @@ control_persist_detach(void)
                error("%s: open(\"/dev/null\"): %s", __func__,
                    strerror(errno));
        } else {
+               keep_stderr = log_is_on_stderr() && debug_flag;
                if (dup2(devnull, STDIN_FILENO) == -1 ||
-                   dup2(devnull, STDOUT_FILENO) == -1)
+                   dup2(devnull, STDOUT_FILENO) == -1 ||
+                   (!keep_stderr && dup2(devnull, STDERR_FILENO) == -1))
                        error("%s: dup2: %s", __func__, strerror(errno));
                if (devnull > STDERR_FILENO)
                        close(devnull);