From e988dba98d852d08707d00eec0072548fdf2eb24 Mon Sep 17 00:00:00 2001 From: Jeff Law Date: Wed, 14 Dec 2011 13:14:56 -0800 Subject: BZ #5245: pthread_create returns EAGAIN for stack allocation failure, not ENOMEM. --- nptl/ChangeLog | 5 +++++ nptl/pthread_create.c | 5 +++-- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/nptl/ChangeLog b/nptl/ChangeLog index 448aa93..bdf6129 100644 --- a/nptl/ChangeLog +++ b/nptl/ChangeLog @@ -1,3 +1,8 @@ +2011-12-14 Jeff Law + + [BZ #5245] + * pthread_create.c (__pthread_create_2_1): Translate ENOMEM to EAGAIN. + 2011-11-28 Andreas Schwab * sysdeps/unix/sysv/linux/i386/i486/pthread_cond_wait.S: Handle diff --git a/nptl/pthread_create.c b/nptl/pthread_create.c index f1113fb..6250d03 100644 --- a/nptl/pthread_create.c +++ b/nptl/pthread_create.c @@ -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 -- cgit v1.1