From 08f8dd1e58f20be82477d37cfd12b7f14be33f9b Mon Sep 17 00:00:00 2001 From: Markos Chandras Date: Wed, 23 Jan 2013 09:12:46 +0000 Subject: libc/statfs64: Skip conversion code for new architectures Fixes the following tests in LTP statfs02_64 ( test case #5 ) The purpose of this test is to pass an invalid pointer to the statfs64 syscall and check if the kernel returns EFAULT or not. However, uClibc creates a new statfs struct which is then passed to the kernel. As a result of which, the kernel returns 0 because the newly created statfs structure is valid. But, when copying the contens of the new pointer to the old userspace one, the uClibc segfauls because the old pointer is invalid. Old architectures are doomed to suffer by this problem but new architectures can use the statfs64 syscall directly so that the userspace pointer is passed directly to the kernel and get the correct errno at the end. Signed-off-by: Markos Chandras Signed-off-by: Bernhard Reutner-Fischer --- libc/misc/statfs/statfs64.c | 9 +++++++++ 1 file changed, 9 insertions(+) (limited to 'libc/misc/statfs') diff --git a/libc/misc/statfs/statfs64.c b/libc/misc/statfs/statfs64.c index ce8211b3e..b1a33b790 100644 --- a/libc/misc/statfs/statfs64.c +++ b/libc/misc/statfs/statfs64.c @@ -21,9 +21,11 @@ #include #include #include +#include extern __typeof(statfs) __libc_statfs; +#if defined __NR_statfs /* Return information about the filesystem on which FILE resides. */ int statfs64 (const char *file, struct statfs64 *buf) { @@ -51,4 +53,11 @@ int statfs64 (const char *file, struct statfs64 *buf) return 0; } +#else +int statfs64 (const char *file, struct statfs64 *buf) +{ + return INLINE_SYSCALL(statfs64, 3, file, sizeof(*buf), buf); +} +#endif + libc_hidden_def(statfs64) -- cgit v1.2.3