From 677adae2b0cdb267b9c3fc46e7b4e330778c9edc Mon Sep 17 00:00:00 2001 From: Markos Chandras Date: Thu, 11 Oct 2012 12:24:12 +0100 Subject: lstat: Use fstatat64 if arch does not have the lstat syscall Signed-off-by: Markos Chandras Signed-off-by: Bernhard Reutner-Fischer --- libc/sysdeps/linux/common/lstat.c | 26 ++++++++++++++++++++------ 1 file changed, 20 insertions(+), 6 deletions(-) (limited to 'libc') diff --git a/libc/sysdeps/linux/common/lstat.c b/libc/sysdeps/linux/common/lstat.c index db72d1f60..2fa3de1c2 100644 --- a/libc/sysdeps/linux/common/lstat.c +++ b/libc/sysdeps/linux/common/lstat.c @@ -10,12 +10,23 @@ #include #include #include -#include "xstatconv.h" + +#if defined __NR_fstatat64 && !defined __NR_lstat +# include +int lstat(const char *file_name, struct stat *buf) +{ + return fstatat(AT_FDCWD, file_name, buf, AT_SYMLINK_NOFOLLOW); +} +libc_hidden_def(lstat) + +/* For systems which have both, prefer the old one */ +#else +# include "xstatconv.h" int lstat(const char *file_name, struct stat *buf) { int result; -#ifdef __NR_lstat64 +# ifdef __NR_lstat64 /* normal stat call has limited values for various stat elements * e.g. uid device major/minor etc. * so we use 64 variant if available @@ -26,19 +37,22 @@ int lstat(const char *file_name, struct stat *buf) if (result == 0) { __xstat32_conv(&kbuf, buf); } -#else +# else struct kernel_stat kbuf; result = INLINE_SYSCALL(lstat, 2, file_name, &kbuf); if (result == 0) { __xstat_conv(&kbuf, buf); } -#endif +# endif /* __NR_lstat64 */ return result; } libc_hidden_def(lstat) -#if ! defined __NR_lstat64 && defined __UCLIBC_HAS_LFS__ +# if ! defined __NR_fstatat64 && ! defined __NR_lstat64 \ + && defined __UCLIBC_HAS_LFS__ strong_alias_untyped(lstat,lstat64) libc_hidden_def(lstat64) -#endif +# endif + +#endif /* __NR_fstatat64 */ -- cgit v1.2.3