From: Zbigniew Jędrzejewski-Szmek Date: Sat, 9 Apr 2016 01:08:29 +0000 (-0400) Subject: basic/util: check return value of dup2 in fork_agent() X-Git-Tag: v231.3~198 X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=commitdiff_plain;h=794becf1e6b0c357ad0d560b9c53e172cdb86e0b;p=elogind.git basic/util: check return value of dup2 in fork_agent() CID #1304689. --- diff --git a/src/basic/util.c b/src/basic/util.c index b049a4485..c6d3442c9 100644 --- a/src/basic/util.c +++ b/src/basic/util.c @@ -424,13 +424,17 @@ int fork_agent(pid_t *pid, const int except[], unsigned n_except, const char *pa _exit(EXIT_FAILURE); } - if (!stdout_is_tty) - dup2(fd, STDOUT_FILENO); + if (!stdout_is_tty && dup2(fd, STDOUT_FILENO) < 0) { + log_error_errno(errno, "Failed to dup2 /dev/tty: %m"); + _exit(EXIT_FAILURE); + } - if (!stderr_is_tty) - dup2(fd, STDERR_FILENO); + if (!stderr_is_tty && dup2(fd, STDERR_FILENO) < 0) { + log_error_errno(errno, "Failed to dup2 /dev/tty: %m"); + _exit(EXIT_FAILURE); + } - if (fd > 2) + if (fd > STDERR_FILENO) close(fd); }