0146d90
--- make-3.80/misc.c.jj	2002-09-12 18:15:58.000000000 -0400
0146d90
+++ make-3.80/misc.c	2005-08-22 05:46:05.000000000 -0400
0146d90
@@ -311,17 +311,31 @@ strerror (errnum)
0146d90
 /* Print an error message from errno.  */
0146d90
 
0146d90
+void
0146d90
+perror_with_name_err (const char *str, const char *name, int errnum)
0146d90
+{
0146d90
+  error (NILF, _("%s%s: %s"), str, name, strerror (errnum));
0146d90
+}
0146d90
+
0146d90
 void
0146d90
 perror_with_name (const char *str, const char *name)
0146d90
 {
0146d90
-  error (NILF, _("%s%s: %s"), str, name, strerror (errno));
0146d90
+  perror_with_name_err (str, name, errno);
0146d90
 }
0146d90
 
0146d90
 /* Print an error message from errno and exit.  */
0146d90
 
0146d90
+void
0146d90
+pfatal_with_name_err (const char *name, int errnum)
0146d90
+{
0146d90
+  fatal (NILF, _("%s: %s"), name, strerror (errnum));
0146d90
+
0146d90
+  /* NOTREACHED */
0146d90
+}
0146d90
+
0146d90
 void
0146d90
 pfatal_with_name (const char *name)
0146d90
 {
0146d90
-  fatal (NILF, _("%s: %s"), name, strerror (errno));
0146d90
+  pfatal_with_name_err (name, errno);
0146d90
 
0146d90
   /* NOTREACHED */
0146d90
 }
0146d90
0146d90
--- make-3.81/main.c.jj	2006-05-23 12:51:25.000000000 +0200
0146d90
+++ make-3.81/main.c	2006-05-23 12:50:48.000000000 +0200
0146d90
@@ -1502,13 +1502,13 @@
0146d90
 	    strcat (template, DEFAULT_TMPFILE);
0146d90
 	    outfile = open_tmpfile (&stdin_nm, template);
0146d90
 	    if (outfile == 0)
0146d90
-	      pfatal_with_name (_("fopen (temporary file)"));
0146d90
+	      pfatal_with_name_err (_("fopen (temporary file)"), errno);
0146d90
 	    while (!feof (stdin) && ! ferror (stdin))
0146d90
 	      {
0146d90
 		char buf[2048];
0146d90
 		unsigned int n = fread (buf, 1, sizeof (buf), stdin);
0146d90
 		if (n > 0 && fwrite (buf, 1, n, outfile) != n)
0146d90
-		  pfatal_with_name (_("fwrite (temporary file)"));
0146d90
+		  pfatal_with_name_err (_("fwrite (temporary file)"), errno);
0146d90
 	      }
0146d90
 	    (void) fclose (outfile);
0146d90
 
0146d90
@@ -1681,7 +1681,7 @@
0146d90
     else if ((job_rfd = dup (job_fds[0])) < 0)
0146d90
       {
0146d90
         if (errno != EBADF)
0146d90
-          pfatal_with_name (_("dup jobserver"));
0146d90
+          pfatal_with_name_err (_("dup jobserver"), errno);
0146d90
 
0146d90
         error (NILF,
0146d90
                _("warning: jobserver unavailable: using -j1.  Add `+' to parent make rule."));
0146d90
@@ -1721,7 +1721,7 @@
0146d90
       char c = '+';
0146d90
 
0146d90
       if (pipe (job_fds) < 0 || (job_rfd = dup (job_fds[0])) < 0)
0146d90
-	pfatal_with_name (_("creating jobs pipe"));
0146d90
+	pfatal_with_name_err (_("creating jobs pipe"), errno);
0146d90
 
0146d90
       /* Every make assumes that it always has one job it can run.  For the
0146d90
          submakes it's the token they were given by their parent.  For the
0146d90
@@ -1736,7 +1736,7 @@
0146d90
 
0146d90
           EINTRLOOP (r, write (job_fds[1], &c, 1));
0146d90
           if (r != 1)
0146d90
-            pfatal_with_name (_("init jobserver pipe"));
0146d90
+            pfatal_with_name_err (_("init jobserver pipe"), errno);
0146d90
         }
0146d90
 
0146d90
       /* Fill in the jobserver_fds struct for our children.  */
0146d90
@@ -2151,8 +2151,8 @@
0146d90
   /* If there is a temp file from reading a makefile from stdin, get rid of
0146d90
      it now.  */
0146d90
   if (stdin_nm && unlink (stdin_nm) < 0 && errno != ENOENT)
0146d90
-    perror_with_name (_("unlink (temporary file): "), stdin_nm);
0146d90
+    perror_with_name_err (_("unlink (temporary file): "), stdin_nm, errno);
0146d90
 
0146d90
   {
0146d90
     int status;
0146d90
0146d90
--- make-3.81/make.h.jj	2006-05-23 12:54:45.000000000 +0200
0146d90
+++ make-3.81/make.h	2006-05-23 12:55:00.000000000 +0200
0146d90
@@ -414,6 +414,8 @@
0146d90
 extern void log_working_directory PARAMS ((int));
0146d90
 extern void pfatal_with_name PARAMS ((const char *)) __attribute__ ((noreturn));
0146d90
 extern void perror_with_name PARAMS ((const char *, const char *));
0146d90
+extern void pfatal_with_name_err PARAMS ((const char *, int errnum)) __attribute__ ((noreturn));
0146d90
+extern void perror_with_name_err PARAMS ((const char *, const char *, int errnum));
0146d90
 extern char *savestring PARAMS ((const char *, unsigned int));
0146d90
 extern char *concat PARAMS ((const char *, const char *, const char *));
0146d90
 extern char *xmalloc PARAMS ((unsigned int));
0146d90
0146d90
--- make-3.81/job.c.jj	2006-05-23 13:01:35.000000000 +0200
0146d90
+++ make-3.81/job.c	2006-05-23 13:50:44.000000000 +0200
0146d90
@@ -859,7 +859,7 @@
0146d90
 
0146d90
       EINTRLOOP (r, write (job_fds[1], &token, 1));
0146d90
       if (r != 1)
0146d90
-	pfatal_with_name (_("write jobserver"));
0146d90
+	pfatal_with_name_err (_("write jobserver"), errno);
0146d90
 
0146d90
       DB (DB_JOBS, (_("Released token for child 0x%08lx (%s).\n"),
0146d90
                     (unsigned long int) child, child->file->name));
0146d90
@@ -1699,6 +1699,7 @@
0146d90
 
0146d90
         /* Set interruptible system calls, and read() for a job token.  */
0146d90
 	set_child_handler_action_flags (1, waiting_jobs != NULL);
0146d90
+	errno = 0;
0146d90
 	got_token = read (job_rfd, &token, 1);
0146d90
 	saved_errno = errno;
0146d90
 	set_child_handler_action_flags (0, waiting_jobs != NULL);
0146d90
@@ -1713,10 +1714,14 @@
0146d90
 
0146d90
         /* If the error _wasn't_ expected (EINTR or EBADF), punt.  Otherwise,
0146d90
            go back and reap_children(), and try again.  */
0146d90
-	errno = saved_errno;
0146d90
-        if (errno != EINTR && errno != EBADF)
0146d90
-          pfatal_with_name (_("read jobs pipe"));
0146d90
-        if (errno == EBADF)
0146d90
+        if (saved_errno != EINTR && saved_errno != EBADF)
0146d90
+	  {
0146d90
+	    if (got_token == 0)
0146d90
+	      fatal (NILF, _("read jobs pipe EOF"));
0146d90
+	    else
0146d90
+	      pfatal_with_name_err (_("read jobs pipe"), saved_errno);
0146d90
+	  }
0146d90
+        if (saved_errno == EBADF)
0146d90
           DB (DB_JOBS, ("Read returned EBADF.\n"));
0146d90
       }
0146d90
 #endif
0146d90
@@ -1831,7 +1836,7 @@
0146d90
 	    error (NILF,
0146d90
                    _("cannot enforce load limits on this operating system"));
0146d90
 	  else
0146d90
-	    perror_with_name (_("cannot enforce load limit: "), "getloadavg");
0146d90
+	    perror_with_name_err (_("cannot enforce load limit: "), "getloadavg", errno);
0146d90
 	}
0146d90
       lossage = errno;
0146d90
       load = 0;