]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Consolidate Linux epoll_wait syscall
authorAdhemerval Zanella <adhemerval.zanella@linaro.org>
Mon, 21 Nov 2016 19:40:19 +0000 (17:40 -0200)
committerAdhemerval Zanella <adhemerval.zanella@linaro.org>
Wed, 3 May 2017 13:36:43 +0000 (10:36 -0300)
This patch consolidates the epoll_wait Linux syscall generation on
sysdeps/unix/sysv/linux/epoll_wait.c.  The implementation tries to
use __NR_epoll_wait if defined, otherwise calls epoll_pwait.

Checked on i686-linux-gnu, x86_64-linux-gnu, x86_64-linux-gnux32,
arch64-linux-gnu, arm-linux-gnueabihf, and powerpc64le-linux-gnu.

* sysdeps/unix/sysv/linux/epoll_wait.c: New file.
* sysdeps/unix/sysv/linux/generic/epoll_wait.c: Remove file.
* sysdeps/unix/sysv/linux/syscalls.list: Remove epoll_wait from
auto-generation list.

ChangeLog
sysdeps/unix/sysv/linux/Makefile
sysdeps/unix/sysv/linux/epoll_wait.c [moved from sysdeps/unix/sysv/linux/generic/epoll_wait.c with 82% similarity]
sysdeps/unix/sysv/linux/generic/Makefile
sysdeps/unix/sysv/linux/syscalls.list

index a48b9fb7d91b28e65567dc500d41b32e84d1edfa..fa61e5fdb7b720c2639e0e8aa4b4c811f63eb053 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,14 @@
 2016-04-03  Adhemerval Zanella  <adhemerval.zanella@linaro.org>
 
+       * sysdeps/unix/sysv/linux/epoll_wait.c: New file.
+       * sysdeps/unix/sysv/linux/generic/epoll_wait.c: Remove file.
+       * sysdeps/unix/sysv/linux/syscalls.list: Remove epoll_wait from
+       auto-generation list.
+       * sysdeps/unix/sysv/linux/Makefile (sysdep_routines): Add
+       epoll_wait.
+       * sysdeps/unix/sysv/linux/generic/Makefile (sysdep_routines):
+       Remove epoll_wait.
+
        * sysdeps/unix/sysv/linux/alpha/Makefile (sysdep_routines): Add
        osf_select.
        * sysdeps/unix/sysv/linux/alpha/select.c: New file.
index 1872cdb1799ad0c04fbac3941289bb750917566b..a8790b1e51d9b70cff389cddfc2aed9a92e59d5f 100644 (file)
@@ -17,7 +17,7 @@ include $(firstword $(wildcard $(sysdirs:=/sysctl.mk)))
 sysdep_routines += clone umount umount2 readahead \
                   setfsuid setfsgid epoll_pwait signalfd \
                   eventfd eventfd_read eventfd_write prlimit \
-                  personality
+                  personality epoll_wait
 
 CFLAGS-gethostid.c = -fexceptions
 CFLAGS-tst-writev.c += "-DARTIFICIAL_LIMIT=(0x80000000-sysconf(_SC_PAGESIZE))"
similarity index 82%
rename from sysdeps/unix/sysv/linux/generic/epoll_wait.c
rename to sysdeps/unix/sysv/linux/epoll_wait.c
index d9363f1d8d380f9d367832c4110193faaa0157ca..eb6e6d3ace803421fd0677b498ea13af5474f8e3 100644 (file)
@@ -1,6 +1,6 @@
-/* Copyright (C) 2011-2017 Free Software Foundation, Inc.
+/* Linux epoll_wait syscall implementation.
+   Copyright (C) 2017 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
-   Contributed by Chris Metcalf <cmetcalf@tilera.com>, 2011.
 
    The GNU C Library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Lesser General Public
@@ -24,5 +24,9 @@
 int
 epoll_wait (int epfd, struct epoll_event *events, int maxevents, int timeout)
 {
+#ifdef __NR_epoll_wait
+  return SYSCALL_CANCEL (epoll_wait, epfd, events, maxevents, timeout);
+#else
   return epoll_pwait (epfd, events, maxevents, timeout, NULL);
+#endif
 }
index c1daee23962012c6f77865059a0d96b3ba0e21b6..7e27e7977262031922ba7cec5849033a86f22789 100644 (file)
@@ -1,3 +1,3 @@
 ifeq ($(subdir),misc)
-sysdep_routines += epoll_create epoll_wait inotify_init
+sysdep_routines += epoll_create inotify_init
 endif
index 4d550b8804e49e19934ea665ab3f46ae65efdc25..1a1090311c0d8431bbac5c516370dc4c841700ed 100644 (file)
@@ -12,7 +12,6 @@ delete_module EXTRA   delete_module   3       delete_module
 epoll_create   EXTRA   epoll_create    i:i     epoll_create
 epoll_create1  EXTRA   epoll_create1   i:i     epoll_create1
 epoll_ctl      EXTRA   epoll_ctl       i:iiip  epoll_ctl
-epoll_wait     EXTRA   epoll_wait      Ci:ipii epoll_wait
 eventfd                EXTRA   eventfd2        i:ii    eventfd
 execve         -       execve          i:spp   __execve        execve
 fdatasync      -       fdatasync       Ci:i    fdatasync