From: Paul Eggert Date: Sun, 7 Jul 2019 00:41:52 +0000 (-0700) Subject: Don’t ignore stderr failure when ADDRESS_SANITIZER X-Git-Tag: emacs-27.0.90~2071 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=b39f5e6c9c50b3153c4e7bfac9219f14da73e4d1;p=emacs.git Don’t ignore stderr failure when ADDRESS_SANITIZER * src/emacs.c (close_output_streams): Move from here ... * src/sysdep.c: ... to here, where it really belongs anyway. When ADDRESS_SANITIZER, fflush stderr and check for ferror, to catch stderr output errors even in this case. --- diff --git a/src/emacs.c b/src/emacs.c index 32bb57e2725..fc1a4beec50 100644 --- a/src/emacs.c +++ b/src/emacs.c @@ -29,8 +29,6 @@ along with GNU Emacs. If not, see . */ #include #include -#include - #define MAIN_PROGRAM #include "lisp.h" #include "sysstdio.h" @@ -661,24 +659,6 @@ argmatch (char **argv, int argc, const char *sstr, const char *lstr, } } -/* Close standard output and standard error, reporting any write - errors as best we can. This is intended for use with atexit. */ -static void -close_output_streams (void) -{ - if (close_stream (stdout) != 0) - { - emacs_perror ("Write error to standard output"); - _exit (EXIT_FAILURE); - } - - /* Do not close stderr if addresses are being sanitized, as the - sanitizer might report to stderr after this function is - invoked. */ - if (!ADDRESS_SANITIZER && close_stream (stderr) != 0) - _exit (EXIT_FAILURE); -} - #ifdef HAVE_PDUMPER static const char * diff --git a/src/sysdep.c b/src/sysdep.c index 4f89e8aba10..48eebb594f7 100644 --- a/src/sysdep.c +++ b/src/sysdep.c @@ -30,6 +30,7 @@ along with GNU Emacs. If not, see . */ #include #include +#include #include #include @@ -2768,6 +2769,25 @@ safe_strsignal (int code) return signame; } +/* Close standard output and standard error, reporting any write + errors as best we can. This is intended for use with atexit. */ +void +close_output_streams (void) +{ + if (close_stream (stdout) != 0) + { + emacs_perror ("Write error to standard output"); + _exit (EXIT_FAILURE); + } + + /* Do not close stderr if addresses are being sanitized, as the + sanitizer might report to stderr after this function is invoked. */ + if (ADDRESS_SANITIZER + ? fflush_unlocked (stderr) != 0 || ferror (stderr) + : close_stream (stderr) != 0) + _exit (EXIT_FAILURE); +} + #ifndef DOS_NT /* For make-serial-process */ int diff --git a/src/sysstdio.h b/src/sysstdio.h index 3ff1d6a572a..a2364c4e1fb 100644 --- a/src/sysstdio.h +++ b/src/sysstdio.h @@ -24,6 +24,7 @@ along with GNU Emacs. If not, see . */ #include extern FILE *emacs_fopen (char const *, char const *); +extern void close_output_streams (void); #if O_BINARY # define FOPEN_BINARY "b"