From: Paul Eggert Date: Tue, 16 Jul 2013 07:05:41 +0000 (-0700) Subject: Fix porting bug to older POSIXish platforms. X-Git-Tag: emacs-24.3.90~173^2^2~42^2~45^2~387^2~1783 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=c7ddc792b747fdf4fde822df0cf9c7b712be4219;p=emacs.git Fix porting bug to older POSIXish platforms. * sysdep.c (emacs_pipe): New function, that implements pipe2 (fd, O_CLOEXEC) even on hosts that lack O_CLOEXEC. This should port better to CentOS 5 and to Mac OS X 10.6. All calls to pipe2 changed. Fixes: debbugs:14862 --- diff --git a/src/ChangeLog b/src/ChangeLog index bc71a482a5d..4d819413b42 100644 --- a/src/ChangeLog +++ b/src/ChangeLog @@ -1,5 +1,11 @@ 2013-07-16 Paul Eggert + Fix porting bug to older POSIXish platforms (Bug#14862). + * sysdep.c (emacs_pipe): New function, that implements + pipe2 (fd, O_CLOEXEC) even on hosts that lack O_CLOEXEC. + This should port better to CentOS 5 and to Mac OS X 10.6. + All calls to pipe2 changed. + Prefer list1 (X) to Fcons (X, Qnil) when building lists. This makes the code easier to read and the executable a bit smaller. Do not replace all calls to Fcons that happen to create lists, diff --git a/src/alloc.c b/src/alloc.c index b71cdb98d78..b52e3de0494 100644 --- a/src/alloc.c +++ b/src/alloc.c @@ -4741,7 +4741,7 @@ valid_pointer_p (void *p) Unfortunately, we cannot use NULL_DEVICE here, as emacs_write may not validate p in that case. */ - if (pipe2 (fd, O_CLOEXEC) == 0) + if (emacs_pipe (fd) == 0) { bool valid = emacs_write (fd[1], (char *) p, 16) == 16; emacs_close (fd[1]); diff --git a/src/callproc.c b/src/callproc.c index 86d82466801..facaac60f2a 100644 --- a/src/callproc.c +++ b/src/callproc.c @@ -524,7 +524,7 @@ usage: (call-process PROGRAM &optional INFILE DESTINATION DISPLAY &rest ARGS) * { #ifndef MSDOS int fd[2]; - if (pipe2 (fd, O_CLOEXEC) != 0) + if (emacs_pipe (fd) != 0) { int pipe_errno = errno; emacs_close (filefd); diff --git a/src/emacs.c b/src/emacs.c index 7ad9739530b..cf3a3c68932 100644 --- a/src/emacs.c +++ b/src/emacs.c @@ -985,7 +985,7 @@ main (int argc, char **argv) use a pipe for synchronization. The parent waits for the child to close its end of the pipe (using `daemon-initialized') before exiting. */ - if (pipe2 (daemon_pipe, O_CLOEXEC) != 0) + if (emacs_pipe (daemon_pipe) != 0) { fprintf (stderr, "Cannot pipe!\n"); exit (1); diff --git a/src/lisp.h b/src/lisp.h index a54b2e07057..6a551bb499d 100644 --- a/src/lisp.h +++ b/src/lisp.h @@ -4094,6 +4094,7 @@ extern void init_random (void); extern void emacs_backtrace (int); extern _Noreturn void emacs_abort (void) NO_INLINE; extern int emacs_open (const char *, int, int); +extern int emacs_pipe (int[2]); extern int emacs_close (int); extern ptrdiff_t emacs_read (int, char *, ptrdiff_t); extern ptrdiff_t emacs_write (int, const char *, ptrdiff_t); diff --git a/src/nsterm.m b/src/nsterm.m index 5cbddd2a990..340ef3b00a2 100644 --- a/src/nsterm.m +++ b/src/nsterm.m @@ -4142,7 +4142,7 @@ ns_term_init (Lisp_Object display_name) if (selfds[0] == -1) { - if (pipe2 (selfds, O_CLOEXEC) != 0) + if (emacs_pipe (selfds) != 0) { fprintf (stderr, "Failed to create pipe: %s\n", emacs_strerror (errno)); diff --git a/src/process.c b/src/process.c index 94ffc37ffe7..125a9389341 100644 --- a/src/process.c +++ b/src/process.c @@ -1651,11 +1651,11 @@ create_process (Lisp_Object process, char **new_argv, Lisp_Object current_dir) else #endif /* HAVE_PTYS */ { - if (pipe2 (sv, O_CLOEXEC) != 0) + if (emacs_pipe (sv) != 0) report_file_error ("Creating pipe", Qnil); inchannel = sv[0]; forkout = sv[1]; - if (pipe2 (sv, O_CLOEXEC) != 0) + if (emacs_pipe (sv) != 0) { int pipe_errno = errno; emacs_close (inchannel); @@ -1667,7 +1667,7 @@ create_process (Lisp_Object process, char **new_argv, Lisp_Object current_dir) } #ifndef WINDOWSNT - if (pipe2 (wait_child_setup, O_CLOEXEC) != 0) + if (emacs_pipe (wait_child_setup) != 0) report_file_error ("Creating pipe", Qnil); #endif diff --git a/src/sysdep.c b/src/sysdep.c index f614d8bc557..82f490e9538 100644 --- a/src/sysdep.c +++ b/src/sysdep.c @@ -2201,6 +2201,20 @@ emacs_fopen (char const *file, char const *mode) return fd < 0 ? 0 : fdopen (fd, mode); } +/* Create a pipe for Emacs use. */ + +int +emacs_pipe (int fd[2]) +{ + int result = pipe2 (fd, O_CLOEXEC); + if (! O_CLOEXEC && result == 0) + { + fcntl (fd[0], F_SETFD, FD_CLOEXEC); + fcntl (fd[1], F_SETFD, FD_CLOEXEC); + } + return result; +} + /* Approximate posix_close and POSIX_CLOSE_RESTART well enough for Emacs. For the background behind this mess, please see Austin Group defect 529 . */