BZ #5245: pthread_create returns EAGAIN for stack allocation failure, not ENOMEM.
authorJeff Law <law@redhat.com>
Wed, 14 Dec 2011 21:14:56 +0000 (13:14 -0800)
committerRoland McGrath <roland@hack.frob.com>
Wed, 14 Dec 2011 21:14:56 +0000 (13:14 -0800)
nptl/ChangeLog
nptl/pthread_create.c

index 448aa93..bdf6129 100644 (file)
@@ -1,3 +1,8 @@
+2011-12-14  Jeff Law  <law@redhat.com>
+
+       [BZ #5245]
+       * pthread_create.c (__pthread_create_2_1): Translate ENOMEM to EAGAIN.
+
 2011-11-28  Andreas Schwab  <schwab@redhat.com>
 
        * sysdeps/unix/sysv/linux/i386/i486/pthread_cond_wait.S: Handle
index f1113fb..6250d03 100644 (file)
@@ -457,8 +457,9 @@ __pthread_create_2_1 (newthread, attr, start_routine, arg)
   int err = ALLOCATE_STACK (iattr, &pd);
   if (__builtin_expect (err != 0, 0))
     /* Something went wrong.  Maybe a parameter of the attributes is
-       invalid or we could not allocate memory.  */
-    return err;
+       invalid or we could not allocate memory.  Note we have to
+       translate error codes.  */
+    return err == ENOMEM ? EAGAIN : err;
 
 
   /* Initialize the TCB.  All initializations with zero should be