[Python-checkins] cpython: Issue 14359: Only use O_CLOEXEC in _posixmodule.c if it is defined.
ross.lagerwall
python-checkins at python.org
Sun Mar 18 14:57:22 CET 2012
http://hg.python.org/cpython/rev/fe1dfc066a38
changeset: 75812:fe1dfc066a38
parent: 75803:b26056192653
user: Ross Lagerwall <rosslagerwall at gmail.com>
date: Sun Mar 18 15:55:10 2012 +0200
summary:
Issue 14359: Only use O_CLOEXEC in _posixmodule.c if it is defined.
Based on patch from Hervé Coatanhay.
files:
Modules/_posixsubprocess.c | 13 ++++++++++++-
1 files changed, 12 insertions(+), 1 deletions(-)
diff --git a/Modules/_posixsubprocess.c b/Modules/_posixsubprocess.c
--- a/Modules/_posixsubprocess.c
+++ b/Modules/_posixsubprocess.c
@@ -204,7 +204,18 @@
int fd_dir_fd;
if (start_fd >= end_fd)
return;
- fd_dir_fd = open(FD_DIR, O_RDONLY | O_CLOEXEC, 0);
+#ifdef O_CLOEXEC
+ fd_dir_fd = open(FD_DIR, O_RDONLY | O_CLOEXEC, 0);
+#else
+ fd_dir_fd = open(FD_DIR, O_RDONLY, 0);
+#ifdef FD_CLOEXEC
+ {
+ int old = fcntl(fd_dir_fd, F_GETFD);
+ if (old != -1)
+ fcntl(fd_dir_fd, F_SETFD, old | FD_CLOEXEC);
+ }
+#endif
+#endif
if (fd_dir_fd == -1) {
/* No way to get a list of open fds. */
_close_fds_by_brute_force(start_fd, end_fd, py_fds_to_keep);
--
Repository URL: http://hg.python.org/cpython
More information about the Python-checkins
mailing list