From 80b0b55af2faa2e314d61d2f17fc24c9cfa94a34 Mon Sep 17 00:00:00 2001 From: Eric Andersen Date: Fri, 15 Nov 2002 14:06:44 +0000 Subject: Cleanup a few structural wierdnesses --- libc/sysdeps/linux/common/ftruncate64.c | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) (limited to 'libc/sysdeps/linux/common/ftruncate64.c') diff --git a/libc/sysdeps/linux/common/ftruncate64.c b/libc/sysdeps/linux/common/ftruncate64.c index 0ab6fd5b9..76b0c0636 100644 --- a/libc/sysdeps/linux/common/ftruncate64.c +++ b/libc/sysdeps/linux/common/ftruncate64.c @@ -19,15 +19,17 @@ #include #include -#if defined __UCLIBC_HAS_LFS__ && defined __NR_ftruncate64 +#if defined __NR_ftruncate64 -#if __WORDSIZE == 64 +#if __WORDSIZE == 64 || (defined(__powerpc__) && defined (__UCLIBC_HAS_LFS__)) /* For a 64 bit machine, life is simple... */ _syscall2(int, ftruncate64, int, fd, __off64_t, length); #elif __WORDSIZE == 32 +#if defined __UCLIBC_HAS_LFS__ + #ifndef INLINE_SYSCALL #define INLINE_SYSCALL(name, nr, args...) __syscall_ftruncate64 (args) #define __NR___syscall_ftruncate64 __NR_ftruncate64 @@ -42,11 +44,11 @@ int ftruncate64 (int fd, __off64_t length) uint32_t high = length >> 32; return INLINE_SYSCALL(ftruncate64, 3, fd, __LONG_LONG_PAIR (high, low)); } +#endif /* __UCLIBC_HAS_LFS__ */ -#else +#else /* __WORDSIZE */ #error Your machine is not 64 bit or 32 bit, I am dazed and confused. #endif /* __WORDSIZE */ -#endif /* __UCLIBC_HAS_LFS__ */ - +#endif -- cgit v1.2.3