diff options
author | Jakub Jelinek <jakub@redhat.com> | 2006-02-03 09:39:28 +0000 |
---|---|---|
committer | Jakub Jelinek <jakub@redhat.com> | 2006-02-03 09:39:28 +0000 |
commit | 9f57ac239bd04f64ae20f6e7b35f387ae6605312 (patch) | |
tree | 1971d9c5a6261ff535fec20e8be494fac1f61eb2 /sysdeps/unix/sysv/linux/openat.c | |
parent | c3a8c11b0c6a6e44e98dcd4bb0fdb397e4fd56f7 (diff) |
Updated to fedora-glibc-20060203T0932
Diffstat (limited to 'sysdeps/unix/sysv/linux/openat.c')
-rw-r--r-- | sysdeps/unix/sysv/linux/openat.c | 19 |
1 files changed, 4 insertions, 15 deletions
diff --git a/sysdeps/unix/sysv/linux/openat.c b/sysdeps/unix/sysv/linux/openat.c index 67e9df2e45..4c1f302ab0 100644 --- a/sysdeps/unix/sysv/linux/openat.c +++ b/sysdeps/unix/sysv/linux/openat.c @@ -30,7 +30,8 @@ #if !defined OPENAT && !defined __ASSUME_ATFCTS # define OPENAT openat - +/* Set errno after a failed call. If BUF is not null, + it is a /proc/self/fd/ path name we just tried to use. */ void attribute_hidden __atfct_seterrno (int errval, int fd, const char *buf) @@ -39,7 +40,7 @@ __atfct_seterrno (int errval, int fd, const char *buf) { struct stat64 st; - if (errval == ENOTDIR) + if (errval == ENOTDIR || errval == ENOENT) { /* This can mean either the file descriptor is invalid or /proc is not mounted. */ @@ -48,23 +49,11 @@ __atfct_seterrno (int errval, int fd, const char *buf) return; /* If /proc is not mounted there is nothing we can do. */ - if (S_ISDIR (st.st_mode) + if ((errval != ENOTDIR || S_ISDIR (st.st_mode)) && (__xstat64 (_STAT_VER, "/proc/self/fd", &st) != 0 || !S_ISDIR (st.st_mode))) errval = ENOSYS; } - else if (errval == ENOENT) - { - /* This could mean the file descriptor is not valid. We - reuse BUF for the stat call. Find the slash after the - file descriptor number. */ - *(char *) strchr (buf + sizeof "/proc/self/fd", '/') = '\0'; - - int e = __lxstat64 (_STAT_VER, buf, &st); - if ((e == -1 && errno == ENOENT) - ||(e == 0 && !S_ISLNK (st.st_mode))) - errval = EBADF; - } } __set_errno (errval); |