X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fselect%2Fselect.c;h=02fd75c3828aca664bf6d695d82e30003c34619a;hb=74e704006a0004058fc38806a19c1552b1e2463d;hp=f93597b55cf78012a61b5d047c153e82bb1265e2;hpb=400c5e5c8307a2ebe44ef1f203f5a15669f20347;p=musl diff --git a/src/select/select.c b/src/select/select.c index f93597b5..02fd75c3 100644 --- a/src/select/select.c +++ b/src/select/select.c @@ -1,8 +1,25 @@ #include +#include +#include +#include #include "syscall.h" -#include "libc.h" int select(int n, fd_set *restrict rfds, fd_set *restrict wfds, fd_set *restrict efds, struct timeval *restrict tv) { +#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 }