summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRich Felker <dalias@aerifal.cx>2019-07-16 18:31:33 -0400
committerRich Felker <dalias@aerifal.cx>2019-07-16 18:31:33 -0400
commit03919b26ed41c31876db41f7cee076ced4513fad (patch)
treebe592d50551a1ee8c600e35f5420e840e76a2f5c
parentb07d45eb01e900f0176894fdedab62285f5cb8be (diff)
downloadmusl-03919b26ed41c31876db41f7cee076ced4513fad.tar.gz
musl-03919b26ed41c31876db41f7cee076ced4513fad.tar.bz2
musl-03919b26ed41c31876db41f7cee076ced4513fad.tar.xz
musl-03919b26ed41c31876db41f7cee076ced4513fad.zip
use namespace-safe __lseek for __stdio_seek instead of direct syscall
this probably saves a few bytes, avoids duplicating the clunky lseek/_llseek syscall convention in two places, and sets the stage for fixing broken seeks on x32 and mipsn32.
-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);