From: Fei Jie Date: Fri, 8 Apr 2016 07:59:16 +0000 (+0800) Subject: tests: add epoll_wait.test X-Git-Tag: v4.12~437 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=c75e2c2e4274ffc4ceed087e8171aab6271b6843;p=strace tests: add epoll_wait.test * tests/epoll_wait.c: New file. * tests/epoll_wait.test: New test. * tests/.gitignore: Add epoll_wait. * tests/Makefile.am (check_PROGRAMS): Likewise. (DECODER_TESTS): Add epoll_wait.test. --- diff --git a/tests/.gitignore b/tests/.gitignore index 849d6ef0..9ef0c037 100644 --- a/tests/.gitignore +++ b/tests/.gitignore @@ -28,6 +28,7 @@ dup3 epoll_create epoll_create1 epoll_ctl +epoll_wait eventfd execve execve-v diff --git a/tests/Makefile.am b/tests/Makefile.am index 2a761d8f..7cd3991b 100644 --- a/tests/Makefile.am +++ b/tests/Makefile.am @@ -79,6 +79,7 @@ check_PROGRAMS = \ epoll_create \ epoll_create1 \ epoll_ctl \ + epoll_wait \ eventfd \ execve \ execve-v \ @@ -280,6 +281,7 @@ DECODER_TESTS = \ epoll_create.test \ epoll_create1.test \ epoll_ctl.test \ + epoll_wait.test \ eventfd.test \ execve.test \ execve-v.test \ diff --git a/tests/epoll_wait.c b/tests/epoll_wait.c new file mode 100644 index 00000000..98b431f0 --- /dev/null +++ b/tests/epoll_wait.c @@ -0,0 +1,28 @@ +#include "tests.h" +#include + +#if defined __NR_epoll_wait && defined HAVE_SYS_EPOLL_H + +# include +# include +# include +# include + +int +main(void) +{ + struct epoll_event *const ev = tail_alloc(sizeof(*ev)); + + int rc = syscall(__NR_epoll_wait, -1, ev, 1, -2); + printf("epoll_wait(-1, %p, 1, -2) = %d %s (%m)\n", + ev, rc, errno == ENOSYS ? "ENOSYS" : "EBADF"); + + puts("+++ exited with 0 +++"); + return 0; +} + +#else + +SKIP_MAIN_UNDEFINED("__NR_epoll_wait && HAVE_SYS_EPOLL_H") + +#endif diff --git a/tests/epoll_wait.test b/tests/epoll_wait.test new file mode 100755 index 00000000..83ae161f --- /dev/null +++ b/tests/epoll_wait.test @@ -0,0 +1,6 @@ +#!/bin/sh + +# Check epoll_wait syscall decoding. + +. "${srcdir=.}/init.sh" +run_strace_match_diff -a26