about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog3
-rw-r--r--posix/test-vfork.c11
2 files changed, 11 insertions, 3 deletions
diff --git a/ChangeLog b/ChangeLog
index 79a9ff5762..7c7190166d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,8 @@
 1999-01-19  Ulrich Drepper  <drepper@cygnus.com>
 
+	* posix/test-vfork.c (main): Improve test to check for correct
+	exit code.
+
 	* sysdeps/unix/sysv/linux/i386/vfork.S: Rewrite to use clone.
 
 	* sysdeps/unix/sysv/linux/bits/sched.h: Define CLONE_VFORK.
diff --git a/posix/test-vfork.c b/posix/test-vfork.c
index 9c352897ed..959dcb3b01 100644
--- a/posix/test-vfork.c
+++ b/posix/test-vfork.c
@@ -6,10 +6,13 @@
 
 void noop (void);
 
+#define NR	2	/* Exit code of the child.  */
+
 int
 main (void)
 {
-  int pid;
+  pid_t pid;
+  int status;
 
   printf ("Before vfork\n");
   fflush (stdout);
@@ -20,12 +23,14 @@ main (void)
 	 machines where it is stored on the stack, if vfork wasn't
 	 implemented correctly, */
       noop ();
-      _exit (2);
+      _exit (NR);
     }
   else if (pid < 0)
     error (1, errno, "vfork");
   printf ("After vfork (parent)\n");
-  wait (0);
+  if (waitpid (0, &status, 0) != pid
+      || !WIFEXITED (status) || WEXITSTATUS (NR))
+    exit (1);
   exit (0);
 }