summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/include/unistd.h1
-rw-r--r--src/stdio/__stdio_seek.c10
-rw-r--r--src/unistd/lseek.c5
3 files changed, 6 insertions, 10 deletions
diff --git a/src/include/unistd.h b/src/include/unistd.h
index 6deb1bcc..1b4605c7 100644
--- a/src/include/unistd.h
+++ b/src/include/unistd.h
@@ -9,5 +9,6 @@ hidden int __dup3(int, int, int);
hidden int __mkostemps(char *, int, int);
hidden int __execvpe(const char *, char *const *, char *const *);
hidden int __aio_close(int);
+hidden off_t __lseek(int, off_t, int);
#endif
diff --git a/src/stdio/__stdio_seek.c b/src/stdio/__stdio_seek.c
index 13e06a66..326ab9bc 100644
--- a/src/stdio/__stdio_seek.c
+++ b/src/stdio/__stdio_seek.c
@@ -1,13 +1,7 @@
#include "stdio_impl.h"
+#include <unistd.h>
off_t __stdio_seek(FILE *f, off_t off, int whence)
{
- off_t ret;
-#ifdef SYS__llseek
- if (syscall(SYS__llseek, f->fd, off>>32, off, &ret, whence)<0)
- ret = -1;
-#else
- ret = syscall(SYS_lseek, f->fd, off, whence);
-#endif
- return ret;
+ return __lseek(f->fd, off, whence);
}
diff --git a/src/unistd/lseek.c b/src/unistd/lseek.c
index bf8cd852..b4984f3e 100644
--- a/src/unistd/lseek.c
+++ b/src/unistd/lseek.c
@@ -1,7 +1,7 @@
#include <unistd.h>
#include "syscall.h"
-off_t lseek(int fd, off_t offset, int whence)
+off_t __lseek(int fd, off_t offset, int whence)
{
#ifdef SYS__llseek
off_t result;
@@ -11,4 +11,5 @@ off_t lseek(int fd, off_t offset, int whence)
#endif
}
-weak_alias(lseek, lseek64);
+weak_alias(__lseek, lseek);
+weak_alias(__lseek, lseek64);