X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Ftime%2Fclock_getres.c;h=81c6703761d4484f4001d10a22123a9a5b859ce6;hb=8910efd0e474fab85bf00657a6eeae4d69a87f63;hp=36a0d695b02e29b1bbfd162061cb113c8550bfc2;hpb=aa398f56fa398f2202b04e82c67f822f3233786f;p=musl diff --git a/src/time/clock_getres.c b/src/time/clock_getres.c index 36a0d695..81c67037 100644 --- a/src/time/clock_getres.c +++ b/src/time/clock_getres.c @@ -3,5 +3,19 @@ int clock_getres(clockid_t clk, struct timespec *ts) { +#ifdef SYS_clock_getres_time64 + /* On a 32-bit arch, use the old syscall if it exists. */ + if (SYS_clock_getres != SYS_clock_getres_time64) { + long ts32[2]; + int r = __syscall(SYS_clock_getres, clk, ts32); + if (!r && ts) { + ts->tv_sec = ts32[0]; + ts->tv_nsec = ts32[1]; + } + return __syscall_ret(r); + } +#endif + /* If reaching this point, it's a 64-bit arch or time64-only + * 32-bit arch and we can get result directly into timespec. */ return syscall(SYS_clock_getres, clk, ts); }