From: Andreas Schwab Date: Thu, 29 Oct 2009 18:27:53 +0000 (-0700) Subject: Fix errno handling in posix_openpt. X-Git-Tag: upstream/2.30~13254 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=d79eccd6dd8aa2038a9775689a7072fe3ceb40dc;p=external%2Fglibc.git Fix errno handling in posix_openpt. The implementation of posix_openpt on Linux can fail in a few extra ways if the appropriate pseudo filesystems are not mounted etc. In some of these cases we have to explicitly set errno. --- diff --git a/ChangeLog b/ChangeLog index 99088df..c46e962 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +2009-10-27 Andreas Schwab + + * sysdeps/unix/sysv/linux/getpt.c (__posix_openpt): Make sure + errno is always set when returning unsuccessfully. + 2009-10-29 Andreas Schwab * malloc/memusage.c (update_data): Fix index wraparound handling diff --git a/sysdeps/unix/sysv/linux/getpt.c b/sysdeps/unix/sysv/linux/getpt.c index bb1ea47..6b26fdf 100644 --- a/sysdeps/unix/sysv/linux/getpt.c +++ b/sysdeps/unix/sysv/linux/getpt.c @@ -1,4 +1,4 @@ -/* Copyright (C) 1998, 1999, 2001 Free Software Foundation, Inc. +/* Copyright (C) 1998, 1999, 2001, 2009 Free Software Foundation, Inc. This file is part of the GNU C Library. Contributed by Zack Weinberg , 1998. @@ -64,9 +64,10 @@ __posix_openpt (oflag) } /* If /dev/pts is not mounted then the UNIX98 pseudo terminals - are not usable. */ + are not usable. */ __close (fd); have_no_dev_ptmx = 1; + __set_errno (ENOENT); } else { @@ -76,6 +77,8 @@ __posix_openpt (oflag) return -1; } } + else + __set_errno (ENOENT); return -1; }