diff mbox series

[1/3] Consolidate Linux poll implementation

Message ID 1492710968-7699-1-git-send-email-adhemerval.zanella@linaro.org
State New
Headers show
Series [1/3] Consolidate Linux poll implementation | expand

Commit Message

Adhemerval Zanella Netto April 20, 2017, 5:56 p.m. UTC
This patch consolidates the poll Linux syscall implementation on
sysdeps/unix/sysv/linux/poll.c.  It basically removes poll from
auto-generation list and add a default implementation that either
call __NR_poll directly (if the kernel headers defines it) or
ppoll adjusting the timeout argument (as the generic implementation).

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

	* sysdeps/unix/sysv/linux/generic/poll.c: Remove file.
	* sysdeps/unix/sysv/linux/poll.c: New file.
	* sysdeps/unix/sysv/linux/syscalls.list: Remove poll from
	auto-generation list.
---
 ChangeLog                                    | 7 +++++++
 sysdeps/unix/sysv/linux/{generic => }/poll.c | 8 ++++++--
 sysdeps/unix/sysv/linux/syscalls.list        | 1 -
 3 files changed, 13 insertions(+), 3 deletions(-)
 rename sysdeps/unix/sysv/linux/{generic => }/poll.c (88%)

-- 
2.7.4

Comments

Adhemerval Zanella Netto May 2, 2017, 9:09 p.m. UTC | #1
On 20/04/2017 14:56, Adhemerval Zanella wrote:
> This patch consolidates the poll Linux syscall implementation on

> sysdeps/unix/sysv/linux/poll.c.  It basically removes poll from

> auto-generation list and add a default implementation that either

> call __NR_poll directly (if the kernel headers defines it) or

> ppoll adjusting the timeout argument (as the generic implementation).

> 

> Checked on i686-linux-gnu, x86_64-linux-gnu, x86_64-linux-gnux32,

> aarch64-linux-gnu, arm-linux-gnueabihf, and powerpc64le-linux-gnu.

> 

> 	* sysdeps/unix/sysv/linux/generic/poll.c: Remove file.

> 	* sysdeps/unix/sysv/linux/poll.c: New file.

> 	* sysdeps/unix/sysv/linux/syscalls.list: Remove poll from

> 	auto-generation list.

> ---

>  ChangeLog                                    | 7 +++++++

>  sysdeps/unix/sysv/linux/{generic => }/poll.c | 8 ++++++--

>  sysdeps/unix/sysv/linux/syscalls.list        | 1 -

>  3 files changed, 13 insertions(+), 3 deletions(-)

>  rename sysdeps/unix/sysv/linux/{generic => }/poll.c (88%)

> 

> diff --git a/sysdeps/unix/sysv/linux/generic/poll.c b/sysdeps/unix/sysv/linux/poll.c

> similarity index 88%

> rename from sysdeps/unix/sysv/linux/generic/poll.c

> rename to sysdeps/unix/sysv/linux/poll.c

> index c06d383..5a781dd 100644

> --- a/sysdeps/unix/sysv/linux/generic/poll.c

> +++ b/sysdeps/unix/sysv/linux/poll.c

> @@ -1,6 +1,6 @@

> -/* Copyright (C) 2011-2017 Free Software Foundation, Inc.

> +/* Linux poll 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

> @@ -25,6 +25,9 @@

>  int

>  __poll (struct pollfd *fds, nfds_t nfds, int timeout)

>  {

> +#ifdef __NR_poll

> +  return SYSCALL_CANCEL (poll, fds, nfds, timeout);

> +#else

>    struct timespec timeout_ts;

>    struct timespec *timeout_ts_p = NULL;

>  

> @@ -36,6 +39,7 @@ __poll (struct pollfd *fds, nfds_t nfds, int timeout)

>      }

>  

>    return SYSCALL_CANCEL (ppoll, fds, nfds, timeout_ts_p, NULL, 0);

> +#endif

>  }

>  libc_hidden_def (__poll)

>  weak_alias (__poll, poll)

> diff --git a/sysdeps/unix/sysv/linux/syscalls.list b/sysdeps/unix/sysv/linux/syscalls.list

> index 5d3c417..fcefefc 100644

> --- a/sysdeps/unix/sysv/linux/syscalls.list

> +++ b/sysdeps/unix/sysv/linux/syscalls.list

> @@ -50,7 +50,6 @@ pause		-	pause		Ci:	__libc_pause	pause

>  pipe		-	pipe		i:f	__pipe		pipe

>  pipe2		-	pipe2		i:fi	__pipe2		pipe2

>  pivot_root	EXTRA	pivot_root	i:ss	pivot_root

> -poll		-	poll		Ci:pii	__libc_poll	__poll poll

>  prctl		EXTRA	prctl		i:iiiii	__prctl		prctl

>  putpmsg		-	putpmsg		i:ippii	putpmsg

>  query_module	EXTRA	query_module	i:sipip	__compat_query_module	query_module@GLIBC_2.0:GLIBC_2.23

> 


Ping.
Siddhesh Poyarekar May 3, 2017, 3:37 a.m. UTC | #2
On Thursday 20 April 2017 11:26 PM, Adhemerval Zanella wrote:
> This patch consolidates the poll Linux syscall implementation on

> sysdeps/unix/sysv/linux/poll.c.  It basically removes poll from

> auto-generation list and add a default implementation that either

> call __NR_poll directly (if the kernel headers defines it) or

> ppoll adjusting the timeout argument (as the generic implementation).

> 

> Checked on i686-linux-gnu, x86_64-linux-gnu, x86_64-linux-gnux32,

> aarch64-linux-gnu, arm-linux-gnueabihf, and powerpc64le-linux-gnu.

> 

> 	* sysdeps/unix/sysv/linux/generic/poll.c: Remove file.

> 	* sysdeps/unix/sysv/linux/poll.c: New file.

> 	* sysdeps/unix/sysv/linux/syscalls.list: Remove poll from

> 	auto-generation list.


OK.

Siddhesh
diff mbox series

Patch

diff --git a/sysdeps/unix/sysv/linux/generic/poll.c b/sysdeps/unix/sysv/linux/poll.c
similarity index 88%
rename from sysdeps/unix/sysv/linux/generic/poll.c
rename to sysdeps/unix/sysv/linux/poll.c
index c06d383..5a781dd 100644
--- a/sysdeps/unix/sysv/linux/generic/poll.c
+++ b/sysdeps/unix/sysv/linux/poll.c
@@ -1,6 +1,6 @@ 
-/* Copyright (C) 2011-2017 Free Software Foundation, Inc.
+/* Linux poll 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
@@ -25,6 +25,9 @@ 
 int
 __poll (struct pollfd *fds, nfds_t nfds, int timeout)
 {
+#ifdef __NR_poll
+  return SYSCALL_CANCEL (poll, fds, nfds, timeout);
+#else
   struct timespec timeout_ts;
   struct timespec *timeout_ts_p = NULL;
 
@@ -36,6 +39,7 @@  __poll (struct pollfd *fds, nfds_t nfds, int timeout)
     }
 
   return SYSCALL_CANCEL (ppoll, fds, nfds, timeout_ts_p, NULL, 0);
+#endif
 }
 libc_hidden_def (__poll)
 weak_alias (__poll, poll)
diff --git a/sysdeps/unix/sysv/linux/syscalls.list b/sysdeps/unix/sysv/linux/syscalls.list
index 5d3c417..fcefefc 100644
--- a/sysdeps/unix/sysv/linux/syscalls.list
+++ b/sysdeps/unix/sysv/linux/syscalls.list
@@ -50,7 +50,6 @@  pause		-	pause		Ci:	__libc_pause	pause
 pipe		-	pipe		i:f	__pipe		pipe
 pipe2		-	pipe2		i:fi	__pipe2		pipe2
 pivot_root	EXTRA	pivot_root	i:ss	pivot_root
-poll		-	poll		Ci:pii	__libc_poll	__poll poll
 prctl		EXTRA	prctl		i:iiiii	__prctl		prctl
 putpmsg		-	putpmsg		i:ippii	putpmsg
 query_module	EXTRA	query_module	i:sipip	__compat_query_module	query_module@GLIBC_2.0:GLIBC_2.23