2d4dfd6
diff -Nrup a/job.c b/job.c
2d4dfd6
--- a/job.c	2015-10-29 17:19:17.209430335 -0400
2d4dfd6
+++ b/job.c	2015-10-29 18:24:04.452169281 -0400
2d4dfd6
@@ -1033,7 +1033,7 @@ free_child (struct child *child)
2d4dfd6
 
2d4dfd6
       EINTRLOOP (r, write (job_fds[1], &token, 1));
2d4dfd6
       if (r != 1)
2d4dfd6
-        pfatal_with_name (_("write jobserver"));
2d4dfd6
+        pfatal_with_name_err (_("write jobserver"), errno);
2d4dfd6
 
2d4dfd6
       DB (DB_JOBS, (_("Released token for child %p (%s).\n"),
2d4dfd6
                     child, child->file->name));
2d4dfd6
@@ -2008,6 +2008,7 @@ new_job (struct file *file)
2d4dfd6
 #else
2d4dfd6
         /* Set interruptible system calls, and read() for a job token.  */
2d4dfd6
         set_child_handler_action_flags (1, waiting_jobs != NULL);
2d4dfd6
+        errno = 0;
2d4dfd6
         got_token = read (job_rfd, &token, 1);
2d4dfd6
         saved_errno = errno;
2d4dfd6
         set_child_handler_action_flags (0, waiting_jobs != NULL);
2d4dfd6
@@ -2024,10 +2025,14 @@ new_job (struct file *file)
2d4dfd6
 #ifndef WINDOWS32
2d4dfd6
         /* If the error _wasn't_ expected (EINTR or EBADF), punt.  Otherwise,
2d4dfd6
            go back and reap_children(), and try again.  */
2d4dfd6
-        errno = saved_errno;
2d4dfd6
-        if (errno != EINTR && errno != EBADF)
2d4dfd6
-          pfatal_with_name (_("read jobs pipe"));
2d4dfd6
-        if (errno == EBADF)
2d4dfd6
+        if (saved_errno != EINTR && saved_errno != EBADF)
2d4dfd6
+         {
2d4dfd6
+           if (got_token == 0)
2d4dfd6
+             O (fatal, NILF, _("read jobs pipe EOF"));
2d4dfd6
+           else
2d4dfd6
+             pfatal_with_name_err (_("read jobs pipe"), saved_errno);
2d4dfd6
+         }
2d4dfd6
+        if (saved_errno == EBADF)
2d4dfd6
           DB (DB_JOBS, ("Read returned EBADF.\n"));
2d4dfd6
 #endif
2d4dfd6
       }
2d4dfd6
@@ -2170,7 +2175,9 @@ load_too_high (void)
2d4dfd6
             O (error, NILF,
2d4dfd6
                _("cannot enforce load limits on this operating system"));
2d4dfd6
           else
2d4dfd6
-            perror_with_name (_("cannot enforce load limit: "), "getloadavg");
2d4dfd6
+            perror_with_name_err (_("cannot enforce load limit: "),
2d4dfd6
+                                  "getloadavg", errno);
2d4dfd6
+
2d4dfd6
         }
2d4dfd6
       lossage = errno;
2d4dfd6
       load = 0;
2d4dfd6
diff -Nrup a/main.c b/main.c
2d4dfd6
--- a/main.c	2015-10-29 17:19:17.198430225 -0400
2d4dfd6
+++ b/main.c	2015-10-29 19:12:15.599567039 -0400
2d4dfd6
@@ -1564,7 +1564,7 @@ main (int argc, char **argv, char **envp
2d4dfd6
                || (job_rfd = dup (job_fds[0])) < 0)
2d4dfd6
         {
2d4dfd6
           if (errno != EBADF)
2d4dfd6
-            pfatal_with_name (_("dup jobserver"));
2d4dfd6
+            pfatal_with_name_err (_("dup jobserver"), errno);
2d4dfd6
 
2d4dfd6
           O (error, NILF,
2d4dfd6
              _("warning: jobserver unavailable: using -j1.  Add '+' to parent make rule."));
2d4dfd6
@@ -1777,13 +1777,13 @@ main (int argc, char **argv, char **envp
2d4dfd6
             strcat (template, DEFAULT_TMPFILE);
2d4dfd6
             outfile = output_tmpfile (&stdin_nm, template);
2d4dfd6
             if (outfile == 0)
2d4dfd6
-              pfatal_with_name (_("fopen (temporary file)"));
2d4dfd6
+              pfatal_with_name_err (_("fopen (temporary file)"), errno);
2d4dfd6
             while (!feof (stdin) && ! ferror (stdin))
2d4dfd6
               {
2d4dfd6
                 char buf[2048];
2d4dfd6
                 unsigned int n = fread (buf, 1, sizeof (buf), stdin);
2d4dfd6
                 if (n > 0 && fwrite (buf, 1, n, outfile) != n)
2d4dfd6
-                  pfatal_with_name (_("fwrite (temporary file)"));
2d4dfd6
+                  pfatal_with_name_err (_("fwrite (temporary file)"), errno);
2d4dfd6
               }
2d4dfd6
             fclose (outfile);
2d4dfd6
 
2d4dfd6
@@ -2019,7 +2019,8 @@ main (int argc, char **argv, char **envp
2d4dfd6
       char c = '+';
2d4dfd6
 
2d4dfd6
       if (pipe (job_fds) < 0 || (job_rfd = dup (job_fds[0])) < 0)
2d4dfd6
-        pfatal_with_name (_("creating jobs pipe"));
2d4dfd6
+        pfatal_with_name_err (_("creating jobs pipe"), errno);
2d4dfd6
+
2d4dfd6
 #endif
2d4dfd6
 
2d4dfd6
       /* Every make assumes that it always has one job it can run.  For the
2d4dfd6
@@ -2039,7 +2040,7 @@ main (int argc, char **argv, char **envp
2d4dfd6
 
2d4dfd6
           EINTRLOOP (r, write (job_fds[1], &c, 1));
2d4dfd6
           if (r != 1)
2d4dfd6
-            pfatal_with_name (_("init jobserver pipe"));
2d4dfd6
+            pfatal_with_name_err (_("init jobserver pipe"), errno);
2d4dfd6
         }
2d4dfd6
 #endif
2d4dfd6
 
2d4dfd6
@@ -2464,7 +2465,7 @@ main (int argc, char **argv, char **envp
2d4dfd6
   /* If there is a temp file from reading a makefile from stdin, get rid of
2d4dfd6
      it now.  */
2d4dfd6
   if (stdin_nm && unlink (stdin_nm) < 0 && errno != ENOENT)
2d4dfd6
-    perror_with_name (_("unlink (temporary file): "), stdin_nm);
2d4dfd6
+    perror_with_name_err (_("unlink (temporary file): "), stdin_nm, errno);
2d4dfd6
 
2d4dfd6
   /* If there were no command-line goals, use the default.  */
2d4dfd6
   if (goals == 0)
2d4dfd6
diff -Nrup a/makeint.h b/makeint.h
2d4dfd6
--- a/makeint.h	2015-10-29 17:19:17.168429926 -0400
2d4dfd6
+++ b/makeint.h	2015-10-29 18:30:44.364147393 -0400
2d4dfd6
@@ -458,6 +458,8 @@ void fatal (const gmk_floc *flocp, size_
2d4dfd6
 void die (int) __attribute__ ((noreturn));
2d4dfd6
 void pfatal_with_name (const char *) __attribute__ ((noreturn));
2d4dfd6
 void perror_with_name (const char *, const char *);
2d4dfd6
+void pfatal_with_name_err (const char *, int errnum) __attribute__ ((noreturn));
2d4dfd6
+void perror_with_name_err (const char *, const char *, int errnum);
2d4dfd6
 #define xstrlen(_s) ((_s)==NULL ? 0 : strlen (_s))
2d4dfd6
 void *xmalloc (unsigned int);
2d4dfd6
 void *xcalloc (unsigned int);
2d4dfd6
diff -Nrup a/output.c b/output.c
2d4dfd6
--- a/output.c	2014-10-05 12:24:51.000000000 -0400
2d4dfd6
+++ b/output.c	2015-10-29 19:04:05.332692965 -0400
2d4dfd6
@@ -705,6 +705,13 @@ fatal (const gmk_floc *flocp, size_t len
2d4dfd6
 /* Print an error message from errno.  */
2d4dfd6
 
2d4dfd6
 void
2d4dfd6
+perror_with_name_err (const char *str, const char *name, int errnum)
2d4dfd6
+{
2d4dfd6
+  const char *err = strerror (errnum);
2d4dfd6
+  OSSS (error, NILF, _("%s%s: %s"), str, name, err);
2d4dfd6
+}
2d4dfd6
+
2d4dfd6
+void
2d4dfd6
 perror_with_name (const char *str, const char *name)
2d4dfd6
 {
2d4dfd6
   const char *err = strerror (errno);
2d4dfd6
@@ -714,6 +721,15 @@ perror_with_name (const char *str, const
2d4dfd6
 /* Print an error message from errno and exit.  */
2d4dfd6
 
2d4dfd6
 void
2d4dfd6
+pfatal_with_name_err (const char *name, int errnum)
2d4dfd6
+{
2d4dfd6
+  const char *err = strerror (errnum);
2d4dfd6
+  OSS (fatal, NILF, _("%s: %s"), name, err);
2d4dfd6
+
2d4dfd6
+  /* NOTREACHED */
2d4dfd6
+}
2d4dfd6
+
2d4dfd6
+void
2d4dfd6
 pfatal_with_name (const char *name)
2d4dfd6
 {
2d4dfd6
   const char *err = strerror (errno);