[git commit future] lseek, lseek64: add cancellation for all THREADS

Peter S. Mazinger ps.m at gmx.net
Wed Apr 20 10:50:38 UTC 2011


commit: http://git.uclibc.org/uClibc/commit/?id=fba47965cff1ab2a104a7ec7379162dd6c47f812
branch: http://git.uclibc.org/uClibc/commit/?id=refs/heads/future

LT_OLD provides cancellable versions, do it for all THREADS.
llseek.c: use newly added macros for offset handling.
Add a comment about endianness issue around offset.
Compile llseek.c only on 32bit archs.
Provide aliases for 64bit archs or if syscall is not available.

Signed-off-by: Peter S. Mazinger <ps.m at gmx.net>
---
 libc/sysdeps/linux/common/llseek.c |   27 +++++++++++----------------
 libc/sysdeps/linux/common/lseek.c  |   22 +++++++++-------------
 2 files changed, 20 insertions(+), 29 deletions(-)

diff --git a/libc/sysdeps/linux/common/llseek.c b/libc/sysdeps/linux/common/llseek.c
index d04a5ec..c46fcee 100644
--- a/libc/sysdeps/linux/common/llseek.c
+++ b/libc/sysdeps/linux/common/llseek.c
@@ -8,25 +8,20 @@
  */
 
 #include <_lfs_64.h>
-#include <unistd.h>
 #include <sys/syscall.h>
+#include <bits/wordsize.h>
 
-#ifdef __NR__llseek
-off64_t lseek64(int fd, off64_t offset, int whence)
+#if defined __NR__llseek && __WORDSIZE == 32
+# include <unistd.h>
+# include <endian.h>
+# include <cancel.h>
+static off64_t __NC(lseek64)(int fd, off64_t offset, int whence)
 {
 	off64_t result;
-	return (off64_t)INLINE_SYSCALL(_llseek, 5, fd, (off_t) (offset >> 32),
-				(off_t) (offset & 0xffffffff), &result, whence) ?: result;
+	/* do we not need to handle the offset with __LONG_LONG_PAIR depending on endianness? */
+	return (off64_t)INLINE_SYSCALL(_llseek, 5, fd, (off_t) OFF64_HI(offset),
+				       (off_t) OFF64_LO(offset), &result, whence) ?: result;
 }
-#else
-off64_t lseek64(int fd, off64_t offset, int whence)
-{
-	return (off64_t)lseek(fd, (off_t) (offset), whence);
-}
-#endif
-#ifndef __LINUXTHREADS_OLD__
-libc_hidden_def(lseek64)
-#else
-libc_hidden_weak(lseek64)
-strong_alias(lseek64,__libc_lseek64)
+CANCELLABLE_SYSCALL(off64_t, lseek64, (int fd, off64_t offset, int whence), (fd, offset, whence))
+lt_libc_hidden(lseek64)
 #endif
diff --git a/libc/sysdeps/linux/common/lseek.c b/libc/sysdeps/linux/common/lseek.c
index 1ed956e..2896e0f 100644
--- a/libc/sysdeps/linux/common/lseek.c
+++ b/libc/sysdeps/linux/common/lseek.c
@@ -9,19 +9,15 @@
 
 #include <sys/syscall.h>
 #include <unistd.h>
+#include <cancel.h>
 
 #ifdef __NR_lseek
-_syscall3(__off_t, lseek, int, fildes, __off_t, offset, int, whence)
-#elif defined __UCLIBC_HAS_LFS__ && defined __NR__llseek /* avoid circular dependency */
-__off_t lseek(int fildes, __off_t offset, int whence)
-{
-	return lseek64(fildes, offset, whence);
-}
+static _syscall3(off_t, __NC(lseek), int, fd, off_t, offset, int, whence)
 #else
 # include <errno.h>
-__off_t lseek(int fildes, __off_t offset attribute_unused, int whence)
+static off_t __NC(lseek)(int fd, off_t offset attribute_unused, int whence)
 {
-	if (fildes < 0) {
+	if (fd < 0) {
 		__set_errno(EBADF);
 		return -1;
 	}
@@ -40,9 +36,9 @@ __off_t lseek(int fildes, __off_t offset attribute_unused, int whence)
 	return -1;
 }
 #endif
-#ifndef __LINUXTHREADS_OLD__
-libc_hidden_def(lseek)
-#else
-libc_hidden_weak(lseek)
-strong_alias(lseek,__libc_lseek)
+CANCELLABLE_SYSCALL(off_t, lseek, (int fd, off_t offset, int whence), (fd, offset, whence))
+lt_libc_hidden(lseek)
+#if defined __UCLIBC_HAS_LFS__ && (__WORDSIZE == 64 || !defined __NR__llseek)
+strong_alias_untyped(lseek,lseek64)
+lt_libc_hidden(lseek64)
 #endif
-- 
1.7.3.4



More information about the uClibc-cvs mailing list