X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;f=src%2Fselect%2Fselect.c;h=7b5f6dcf7a53aaf435db3221d4cd0d7db8f2abd7;hb=c1e27367a9b26b9baac0f37a12349fc36567c8b6;hp=696cb2880efcf1b2c0607f16cb424b203d6d5055;hpb=feee98903cd8119d9a3db62589246a940f44a9f5;p=musl diff --git a/src/select/select.c b/src/select/select.c index 696cb288..7b5f6dcf 100644 --- a/src/select/select.c +++ b/src/select/select.c @@ -1,8 +1,26 @@ #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) { +#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 }