[PATCH 2/4] tests: add epoll_ctl.test

Dmitry V. Levin ldv at altlinux.org
Sun Apr 10 00:29:48 UTC 2016


On Fri, Apr 08, 2016 at 03:59:15PM +0800, Fei Jie wrote:
> * tests/epoll_ctl.c: New file.
> * tests/epoll_ctl.test: New test.
> * tests/.gitignore: Add epoll_ctl.
> * tests/Makefile.am (check_PROGRAMS): Likewise.
> (DECODER_TESTS): Add epoll_ctl.test.
> ---
>  tests/.gitignore     |  1 +
>  tests/Makefile.am    |  2 ++
>  tests/epoll_ctl.c    | 31 +++++++++++++++++++++++++++++++
>  tests/epoll_ctl.test |  6 ++++++
>  4 files changed, 40 insertions(+)
>  create mode 100644 tests/epoll_ctl.c
>  create mode 100755 tests/epoll_ctl.test
> 
> diff --git a/tests/.gitignore b/tests/.gitignore
> index 0478e18..849d6ef 100644
> --- a/tests/.gitignore
> +++ b/tests/.gitignore
> @@ -27,6 +27,7 @@ dup2
>  dup3
>  epoll_create
>  epoll_create1
> +epoll_ctl
>  eventfd
>  execve
>  execve-v
> diff --git a/tests/Makefile.am b/tests/Makefile.am
> index 8dc6673..2a761d8 100644
> --- a/tests/Makefile.am
> +++ b/tests/Makefile.am
> @@ -78,6 +78,7 @@ check_PROGRAMS = \
>  	dup3 \
>  	epoll_create \
>  	epoll_create1 \
> +	epoll_ctl \
>  	eventfd \
>  	execve \
>  	execve-v \
> @@ -278,6 +279,7 @@ DECODER_TESTS = \
>  	dup3.test \
>  	epoll_create.test \
>  	epoll_create1.test \
> +	epoll_ctl.test \
>  	eventfd.test \
>  	execve.test \
>  	execve-v.test \
> diff --git a/tests/epoll_ctl.c b/tests/epoll_ctl.c
> new file mode 100644
> index 0000000..b24bae8
> --- /dev/null
> +++ b/tests/epoll_ctl.c
> @@ -0,0 +1,31 @@
> +#include "tests.h"
> +#include <sys/syscall.h>
> +
> +#ifdef __NR_epoll_ctl
> +
> +# include <errno.h>
> +# include <stdio.h>
> +# include <sys/epoll.h>

Inclusion of <sys/epoll.h> has to be guarded with HAVE_SYS_EPOLL_H.

> +# include <unistd.h>
> +# include <inttypes.h>
> +
> +int
> +main(void)
> +{
> +	struct epoll_event *const ev = tail_alloc(sizeof(struct epoll_event));

sizeof(struct epoll_event) can be replaced with sizeof(*ev).

> +	ev->events = EPOLLIN;
> +	int rc = syscall(__NR_epoll_ctl, -1, EPOLL_CTL_ADD, -1, ev);
> +	printf("epoll_ctl(-1, EPOLL_CTL_ADD, -1, {EPOLLIN,"
> +	       " {u32=%u, u64=%" PRIu64 "}}) = %d %s (%m)\n",
> +	       ev->data.u32, ev->data.u64, rc,
> +	       errno == ENOSYS ? "ENOSYS" : "EBADF");
> +
> +	puts("+++ exited with 0 +++");
> +	return 0;
> +}
> +
> +#else
> +
> +SKIP_MAIN_UNDEFINED("__NR_epoll_create")
> +
> +#endif

Applied with these editions.


-- 
ldv
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 819 bytes
Desc: not available
URL: <http://lists.strace.io/pipermail/strace-devel/attachments/20160410/f7fdb925/attachment.bin>


More information about the Strace-devel mailing list