X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=src%2Fselect%2Fselect.c;h=02fd75c3828aca664bf6d695d82e30003c34619a;hb=e4dd65305a046019123ab34ebdcbe761a3a719ca;hp=12322718f9e1377ae608fc1dceafdefe66d6d12e;hpb=aa398f56fa398f2202b04e82c67f822f3233786f;p=musl diff --git a/src/select/select.c b/src/select/select.c index 12322718..02fd75c3 100644 --- a/src/select/select.c +++ b/src/select/select.c @@ -1,12 +1,25 @@ #include +#include +#include +#include #include "syscall.h" -#include "libc.h" -int select(int n, fd_set *rfds, fd_set *wfds, fd_set *efds, struct timeval *tv) +int select(int n, fd_set *restrict rfds, fd_set *restrict wfds, fd_set *restrict efds, struct timeval *restrict tv) { - int r; - CANCELPT_BEGIN; - r = syscall(SYS_select, n, rfds, wfds, efds, tv); - CANCELPT_END; - return r; +#ifdef SYS_select + return syscall_cp(SYS_select, n, rfds, wfds, efds, tv); +#else + syscall_arg_t data[2] = { 0, _NSIG/8 }; + struct timespec ts; + if (tv) { + if (tv->tv_sec < 0 || tv->tv_usec < 0) + return __syscall_ret(-EINVAL); + time_t extra_secs = tv->tv_usec / 1000000; + ts.tv_nsec = tv->tv_usec % 1000000 * 1000; + const time_t max_time = (1ULL<<8*sizeof(time_t)-1)-1; + ts.tv_sec = extra_secs > max_time - tv->tv_sec ? + max_time : tv->tv_sec + extra_secs; + } + return syscall_cp(SYS_pselect6, n, rfds, wfds, efds, tv ? &ts : 0, data); +#endif }