epoll_create wrapper function is not used

Bran S archsbran at gmail.com
Sun Jul 5 03:17:40 UTC 2020


On Tue, 30 Jun 2020 at 22:13, Dmitry V. Levin <ldv at altlinux.org> wrote:
>
> On Sun, Jun 28, 2020 at 10:24:23PM +0530, Bran S wrote:
> > In tests/epoll_create.c:
> >     const long int size = (long int) 0xdeadbeefffffffffULL;
> >     long rc = syscall(__NR_epoll_create, size);
> >
> > Why syscall(__NR_epoll_create) is used when a wrapper function is
> > available for it in #include <sys/epoll.h>? Are they different in some
> > way? What is the reason for not using the wrapper?
> >
> > In manpage of epoll_create there is a line:
> > "Library support is provided in glibc starting with version 2.3.2."
> > Is this the reason? So that machines with glibc 2.3.2 can also use this?
>
> epoll_create is a syscall obsoleted by epoll_create1, so some libc (e.g.
> musl) implement epoll_create function using epoll_create1 syscall.

But epoll_create1 is also tested the same way by using
`syscall(__NR_epoll_create1)`
Why not use the epoll_create1 wrapper?


> > Also, why the datatype of size parameter is 'long int'? epoll_create's
> > prototype has got the size parameter's datatype to be 'int'.
>
> This is a way of testing that extra bits are ignored.


More information about the Strace-devel mailing list