From: Tudor Bosman Date: Tue, 8 Jul 2014 00:29:32 +0000 (-0700) Subject: Simplify pipe2 / O_CLOEXEC handling in Subprocess.cpp X-Git-Tag: v0.22.0~465 X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=fca9fccb9676d9ac2d9b5c79dca8bd5ae42ad740;p=folly.git Simplify pipe2 / O_CLOEXEC handling in Subprocess.cpp Summary: per @rockyliu's suggestions Test Plan: subprocess_test Reviewed By: rockyliu4@fb.com Subscribers: rockyliu, jhj, lesha, kma FB internal diff: D1423157 --- diff --git a/folly/Subprocess.cpp b/folly/Subprocess.cpp index ac8eab60..db45c9e4 100644 --- a/folly/Subprocess.cpp +++ b/folly/Subprocess.cpp @@ -256,29 +256,25 @@ void Subprocess::spawn( // in case it fails before calling exec() int errFds[2]; #if FOLLY_HAVE_PIPE2 - int r = ::pipe2(errFds, O_CLOEXEC); + checkUnixError(::pipe2(errFds, O_CLOEXEC), "pipe2"); #else - int r = ::pipe(errFds); + checkUnixError(::pipe(errFds), "pipe"); #endif - checkUnixError(r, "pipe"); SCOPE_EXIT { CHECK_ERR(::close(errFds[0])); if (errFds[1] >= 0) { CHECK_ERR(::close(errFds[1])); } }; - // Ask the child to close the read end of the error pipe. - options.fdActions_[errFds[0]] = CLOSE; #if !FOLLY_HAVE_PIPE2 - r = fcntl(errFds[0], F_SETFD, FD_CLOEXEC); - checkUnixError(r, "set FD_CLOEXEC"); + // Ask the child to close the read end of the error pipe. + checkUnixError(fcntl(errFds[0], F_SETFD, FD_CLOEXEC), "set FD_CLOEXEC"); // Set the close-on-exec flag on the write side of the pipe. // This way the pipe will be closed automatically in the child if execve() // succeeds. If the exec fails the child can write error information to the // pipe. - r = fcntl(errFds[1], F_SETFD, FD_CLOEXEC); - checkUnixError(r, "set FD_CLOEXEC"); + checkUnixError(fcntl(errFds[1], F_SETFD, FD_CLOEXEC), "set FD_CLOEXEC"); #endif // Perform the actual work of setting up pipes then forking and @@ -454,12 +450,9 @@ int Subprocess::prepareChild(const Options& options, } } - // Close parent's ends of all pipes - for (auto& p : pipes_) { - if (::close(p.parentFd) == -1) { - return errno; - } - } + // We don't have to explicitly close the parent's end of all pipes, + // as they all have the FD_CLOEXEC flag set and will be closed at + // exec time. // Close all fds that we're supposed to close. for (auto& p : options.fdActions_) {