summaryrefslogtreecommitdiff
path: root/libc/sysdeps/linux/common/readahead.c
diff options
context:
space:
mode:
authorMike Frysinger <vapier@gentoo.org>2013-04-01 05:40:42 -0400
committerMike Frysinger <vapier@gentoo.org>2013-04-01 05:58:03 -0400
commit81c9eaafecd4b3d53ef09931fe2c65de1cda98ca (patch)
treef65720c741a88a037a4291c4004d8eb486c4191b /libc/sysdeps/linux/common/readahead.c
parentee84b8b40004c970ab0ac660cb04f12cc2748e84 (diff)
linux: readahead: convert to SYSCALL_ALIGN_64BIT
The readahead syscall has the 64bit register align issue for all arches. Only mips was handling this though. Clean up the common readahead.c to use the SYSCALL_ALIGN_64BIT define so that we can throw away the mips version and make this work correctly on arm/ppc/xtensa. Signed-off-by: Mike Frysinger <vapier@gentoo.org>
Diffstat (limited to 'libc/sysdeps/linux/common/readahead.c')
-rw-r--r--libc/sysdeps/linux/common/readahead.c21
1 files changed, 8 insertions, 13 deletions
diff --git a/libc/sysdeps/linux/common/readahead.c b/libc/sysdeps/linux/common/readahead.c
index bbd9c0a26..bda0de2c7 100644
--- a/libc/sysdeps/linux/common/readahead.c
+++ b/libc/sysdeps/linux/common/readahead.c
@@ -23,26 +23,21 @@
# include <fcntl.h>
# include <bits/wordsize.h>
-# define __NR___readahead __NR_readahead
-
# if __WORDSIZE == 64
-static __inline__ _syscall3(ssize_t, __readahead, int, fd,
- off_t, offset, size_t, count)
-
-ssize_t readahead(int fd, off_t offset, size_t count)
-{
- return __readahead(fd, offset, count);
-}
+_syscall3(ssize_t, readahead, int, fd, off_t, offset, size_t, count)
# else
-static __inline__ _syscall4(ssize_t, __readahead, int, fd,
- off_t, high_offset, off_t, low_offset, size_t, count)
-
ssize_t readahead(int fd, off64_t offset, size_t count)
{
- return __readahead(fd, (off_t) (offset >> 32), (off_t) (offset & 0xffffffff), count);
+ return INLINE_SYSCALL(readahead,
+# if defined(__UCLIBC_SYSCALL_ALIGN_64BIT__)
+ 5, fd, 0,
+# else
+ 4, fd,
+# endif
+ OFF64_HI_LO(offset), count);
}
# endif