From c84d1f2ed7bbd6926d0831a00ea80299172f65c3 Mon Sep 17 00:00:00 2001 From: Roland McGrath Date: Wed, 2 Oct 2002 08:33:46 +0000 Subject: 2002-10-02 Roland McGrath * sysdeps/unix/sysv/linux/xstatconv.c [STAT_IS_KERNEL_STAT]: Conditionalize the function definitions on this. * sysdeps/unix/sysv/linux/xstat.c (__xstat) [STAT_IS_KERNEL_STAT]: Don't use xstat_conv, just fail if VERS != _STAT_VER_KERNEL. * sysdeps/unix/sysv/linux/fxstat.c (__fxstat) [STAT_IS_KERNEL_STAT]: Likewise. * sysdeps/unix/sysv/linux/lxstat.c (__lxstat) [STAT_IS_KERNEL_STAT]: Likewise. --- sysdeps/unix/sysv/linux/xstat.c | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) (limited to 'sysdeps/unix/sysv/linux/xstat.c') diff --git a/sysdeps/unix/sysv/linux/xstat.c b/sysdeps/unix/sysv/linux/xstat.c index 5f936388db..05e170d17c 100644 --- a/sysdeps/unix/sysv/linux/xstat.c +++ b/sysdeps/unix/sysv/linux/xstat.c @@ -33,25 +33,31 @@ #include -extern int __syscall_stat (const char *__unbounded, struct kernel_stat *__unbounded); +extern int __syscall_stat (const char *__unbounded, + struct kernel_stat *__unbounded); /* Get information about the file NAME in BUF. */ int __xstat (int vers, const char *name, struct stat *buf) { - struct kernel_stat kbuf; - int result; - if (vers == _STAT_VER_KERNEL) return INLINE_SYSCALL (stat, 2, CHECK_STRING (name), CHECK_1 ((struct kernel_stat *) buf)); +#ifdef STAT_IS_KERNEL_STAT + errno = EINVAL; + return -1; +#else + struct kernel_stat kbuf; + int result; + result = INLINE_SYSCALL (stat, 2, CHECK_STRING (name), __ptrvalue (&kbuf)); if (result == 0) result = xstat_conv (vers, &kbuf, buf); return result; +#endif } hidden_def (__xstat) weak_alias (__xstat, _xstat); -- cgit 1.4.1