X-Git-Url: http://nsz.repo.hu/git/?a=blobdiff_plain;ds=sidebyside;f=src%2Fselect%2Fpselect.c;h=4e2d7b073dbad9eee66d09cdab1af9922ce6bc8b;hb=e3bc22f1eff87b8f029a6ab31f1a269d69e4b053;hp=155a6eb0382ce79a265c9ea10e33d6b89be5e91c;hpb=b470030f839a375e5030ec9d44903ef7581c15a2;p=musl diff --git a/src/select/pselect.c b/src/select/pselect.c index 155a6eb0..4e2d7b07 100644 --- a/src/select/pselect.c +++ b/src/select/pselect.c @@ -1,16 +1,13 @@ #include +#include +#include #include "syscall.h" #include "libc.h" -int pselect(int n, fd_set *rfds, fd_set *wfds, fd_set *efds, const struct timespec *ts, const sigset_t *mask) +int pselect(int n, fd_set *restrict rfds, fd_set *restrict wfds, fd_set *restrict efds, const struct timespec *restrict ts, const sigset_t *restrict mask) { - int r; - long data[2] = { (long)mask, 8 }; + syscall_arg_t data[2] = { (uintptr_t)mask, _NSIG/8 }; struct timespec ts_tmp; if (ts) ts_tmp = *ts; - CANCELPT_BEGIN; - r = syscall(SYS_pselect6, n, rfds, wfds, efds, ts ? &ts_tmp : 0, data); - CANCELPT_TRY; - CANCELPT_END; - return r; + return syscall_cp(SYS_pselect6, n, rfds, wfds, efds, ts ? &ts_tmp : 0, data); }