From aad20af475f8e3e1d7d878e82d82d433706ffaff Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Fri, 5 Mar 1999 18:52:41 +0000 Subject: Update. * sysdeps/unix/sysv/linux/ttyname_r.c (__ttyname_r): Remember whether /dev/pts is available. * sysdeps/unix/sysv/linux/ttyname.c (ttyname): Fix handling of dev_pts_available. --- sysdeps/unix/sysv/linux/ttyname.c | 23 ++++++++++++----------- sysdeps/unix/sysv/linux/ttyname_r.c | 29 +++++++++++++++++++---------- 2 files changed, 31 insertions(+), 21 deletions(-) (limited to 'sysdeps/unix') diff --git a/sysdeps/unix/sysv/linux/ttyname.c b/sysdeps/unix/sysv/linux/ttyname.c index a32d1a6..9d345b8 100644 --- a/sysdeps/unix/sysv/linux/ttyname.c +++ b/sysdeps/unix/sysv/linux/ttyname.c @@ -111,7 +111,7 @@ ttyname (fd) char procname[30]; struct stat st, st1; int dostat = 0; - char *name; + char *name = NULL; int save = errno; if (!__isatty (fd)) @@ -139,20 +139,21 @@ ttyname (fd) if (__fxstat (_STAT_VER, fd, &st) < 0) return NULL; - if (dev_pts_available - && __xstat (_STAT_VER, "/dev/pts", &st1) == 0 && S_ISDIR (st1.st_mode)) + if (dev_pts_available) { + if (__xstat (_STAT_VER, "/dev/pts", &st1) == 0 && S_ISDIR (st1.st_mode)) + { #ifdef _STATBUF_ST_RDEV - name = getttyname ("/dev/pts", st.st_rdev, st.st_ino, save, &dostat); + name = getttyname ("/dev/pts", st.st_rdev, st.st_ino, save, &dostat); #else - name = getttyname ("/dev/pts", st.st_dev, st.st_ino, save, &dostat); + name = getttyname ("/dev/pts", st.st_dev, st.st_ino, save, &dostat); #endif - } - else - { - __set_errno (save); - name = NULL; - dev_pts_available = 1; + } + else + { + __set_errno (save); + dev_pts_available = 0; + } } if (!name && dostat != -1) diff --git a/sysdeps/unix/sysv/linux/ttyname_r.c b/sysdeps/unix/sysv/linux/ttyname_r.c index b92c712..ae5a029 100644 --- a/sysdeps/unix/sysv/linux/ttyname_r.c +++ b/sysdeps/unix/sysv/linux/ttyname_r.c @@ -103,6 +103,7 @@ __ttyname_r (fd, buf, buflen) char *buf; size_t buflen; { + static int dev_pts_available = 1; char procname[30]; struct stat st, st1; int dostat = 0; @@ -148,20 +149,28 @@ __ttyname_r (fd, buf, buflen) memcpy (buf, "/dev/pts/", sizeof ("/dev/pts/")); buflen -= sizeof ("/dev/pts/") - 1; - if (__xstat (_STAT_VER, buf, &st1) == 0 && S_ISDIR (st1.st_mode)) + if (dev_pts_available) { + if (__xstat (_STAT_VER, buf, &st1) == 0 && S_ISDIR (st1.st_mode)) + { #ifdef _STATBUF_ST_RDEV - ret = getttyname_r (buf, buflen, st.st_rdev, st.st_ino, save, - &dostat); + ret = getttyname_r (buf, buflen, st.st_rdev, st.st_ino, save, + &dostat); #else - ret = getttyname_r (buf, buflen, st.st_dev, st.st_ino, save, - &dostat); + ret = getttyname_r (buf, buflen, st.st_dev, st.st_ino, save, + &dostat); #endif - } - else - { - __set_errno (save); - ret = ENOENT; + } + else + { + __set_errno (save); + ret = ENOENT; + } + else + { + __set_errno (save); + dev_pts_available = 0; + } } if (ret && dostat != -1) -- cgit v1.1