diff options
author | Rich Felker <dalias@aerifal.cx> | 2011-03-19 21:36:10 -0400 |
---|---|---|
committer | Rich Felker <dalias@aerifal.cx> | 2011-03-19 21:36:10 -0400 |
commit | 685e40bb09f5f24a2af54ea09c97328808f76990 (patch) | |
tree | 73bbf60045bb3a9c8af4f2639e8adb2ad1ea6994 /src/time | |
parent | 462dbfc20788a6c9dd1ea4bb1cef086aa189615a (diff) | |
download | musl-685e40bb09f5f24a2af54ea09c97328808f76990.tar.gz musl-685e40bb09f5f24a2af54ea09c97328808f76990.tar.bz2 musl-685e40bb09f5f24a2af54ea09c97328808f76990.tar.xz musl-685e40bb09f5f24a2af54ea09c97328808f76990.zip |
syscall overhaul part two - unify public and internal syscall interface
with this patch, the syscallN() functions are no longer needed; a
variadic syscall() macro allows syscalls with anywhere from 0 to 6
arguments to be made with a single macro name. also, manually casting
each non-integer argument with (long) is no longer necessary; the
casts are hidden in the macros.
some source files which depended on being able to define the old macro
SYSCALL_RETURNS_ERRNO have been modified to directly use __syscall()
instead of syscall(). references to SYSCALL_SIGSET_SIZE and SYSCALL_LL
have also been changed.
x86_64 has not been tested, and may need a follow-up commit to fix any
minor bugs/oversights.
Diffstat (limited to 'src/time')
-rw-r--r-- | src/time/clock_nanosleep.c | 3 | ||||
-rw-r--r-- | src/time/gettimeofday.c | 3 | ||||
-rw-r--r-- | src/time/time.c | 3 |
3 files changed, 3 insertions, 6 deletions
diff --git a/src/time/clock_nanosleep.c b/src/time/clock_nanosleep.c index ffb9a8af..c777c179 100644 --- a/src/time/clock_nanosleep.c +++ b/src/time/clock_nanosleep.c @@ -1,4 +1,3 @@ -#define SYSCALL_RETURN_ERRNO #include <time.h> #include "syscall.h" #include "libc.h" @@ -7,7 +6,7 @@ int clock_nanosleep(clockid_t clk, int flags, const struct timespec *req, struct { int ret; CANCELPT_BEGIN; - ret = syscall4(__NR_clock_nanosleep, clk, flags, (long)req, (long)rem); + ret = __syscall(__NR_clock_nanosleep, clk, flags, req, rem); CANCELPT_END; return ret; } diff --git a/src/time/gettimeofday.c b/src/time/gettimeofday.c index 2b8a287d..521b4d57 100644 --- a/src/time/gettimeofday.c +++ b/src/time/gettimeofday.c @@ -1,9 +1,8 @@ -#define SYSCALL_RETURN_ERRNO #include <sys/time.h> #include "syscall.h" int gettimeofday(struct timeval *tv, void *tz) { - syscall2(__NR_gettimeofday, (long)tv, 0); + __syscall(__NR_gettimeofday, tv, 0); return 0; } diff --git a/src/time/time.c b/src/time/time.c index 3457dade..2d2cfd44 100644 --- a/src/time/time.c +++ b/src/time/time.c @@ -1,4 +1,3 @@ -#define SYSCALL_RETURN_ERRNO #include <time.h> #include <sys/time.h> #include "syscall.h" @@ -6,7 +5,7 @@ time_t time(time_t *t) { struct timeval tv; - syscall2(__NR_gettimeofday, (long)&tv, 0); + __syscall(__NR_gettimeofday, &tv, 0); if (t) *t = tv.tv_sec; return tv.tv_sec; } |