Compatibility of signalfd/eventfd with older kernels.
authorUlrich Drepper <drepper@redhat.com>
Sun, 26 Jul 2009 19:55:03 +0000 (12:55 -0700)
committerUlrich Drepper <drepper@redhat.com>
Sun, 26 Jul 2009 19:55:03 +0000 (12:55 -0700)
ChangeLog
sysdeps/unix/sysv/linux/eventfd.c
sysdeps/unix/sysv/linux/kernel-features.h
sysdeps/unix/sysv/linux/signalfd.c

index 977f0f8..d32f15b 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,13 @@
 2009-07-26  Ulrich Drepper  <drepper@redhat.com>
 
+       [BZ #10422]
+       * sysdeps/unix/sysv/linux/eventfd.c: Add compatibility for old
+       kernels, dropped when eventfd2 support was added.
+       * sysdeps/unix/sysv/linux/signalfd.c: Add compatibility for old
+       kernels, dropped when signalfd4 support was added.
+       * sysdeps/unix/sysv/linux/kernel-features.h: More CLOEXEC syscalls
+       added, name them.
+
        [BZ #10452]
        * resolv/res_send.c (send_dg): Pass full SERVFAIL, NOTIMP, REFUSED
        replies up.
index 4cd5579..7f69ecd 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2007, 2008 Free Software Foundation, Inc.
+/* Copyright (C) 2007, 2008, 2009 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
 #include <errno.h>
 #include <sys/eventfd.h>
 #include <sysdep.h>
+#include <kernel-features.h>
 
 
 int
 eventfd (int count, int flags)
 {
 #ifdef __NR_eventfd2
-  return INLINE_SYSCALL (eventfd2, 2, count, flags);
-#else
+  int res = INLINE_SYSCALL (eventfd2, 2, count, flags);
+# ifndef __ASSUME_EVENTFD2
+  if (res != -1 || errno != ENOSYS)
+# endif
+    return res;
+#endif
+
+#ifndef __ASSUME_EVENTFD2
   /* The old system call has no flag parameter which is bad.  So we have
      to wait until we have to support to pass additional values to the
      kernel (sys_indirect) before implementing setting flags like
@@ -43,5 +50,7 @@ eventfd (int count, int flags)
   __set_errno (ENOSYS);
   return -1;
 # endif
+#elif !defined __NR_eventfd2
+# error "__ASSUME_EVENTFD2 defined but not __NR_eventfd2"
 #endif
 }
index 4562515..ff065ef 100644 (file)
 # define __ASSUME_SOCK_CLOEXEC 1
 # define __ASSUME_IN_NONBLOCK  1
 # define __ASSUME_PIPE2                1
+# define __ASSUME_EVENTFD2     1
+# define __ASSUME_SIGNALFD4    1
 #endif
 
 /* Support for the accept4 syscall was added in 2.6.28.  */
index 9898f29..c2d974a 100644 (file)
@@ -1,4 +1,4 @@
-/* Copyright (C) 2007, 2008 Free Software Foundation, Inc.
+/* Copyright (C) 2007, 2008, 2009 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
 
    The GNU C Library is free software; you can redistribute it and/or
 #include <signal.h>
 #include <sys/signalfd.h>
 #include <sysdep.h>
+#include <kernel-features.h>
 
 
 int
 signalfd (int fd, const sigset_t *mask, int flags)
 {
 #ifdef __NR_signalfd4
-  return INLINE_SYSCALL (signalfd4, 4, fd, mask, _NSIG / 8, flags);
-#else
+  int res = INLINE_SYSCALL (signalfd4, 4, fd, mask, _NSIG / 8, flags);
+# ifndef __ASSUME_SIGNALFD4
+  if (res != -1 || errno != ENOSYS)
+# endif
+    return res;
+#endif
+
+#ifndef __ASSUME_SIGNALFD4
   /* The old system call has no flag parameter which is bad.  So we have
      to wait until we have to support to pass additional values to the
      kernel (sys_indirect) before implementing setting flags like
@@ -44,5 +51,7 @@ signalfd (int fd, const sigset_t *mask, int flags)
   __set_errno (ENOSYS);
   return -1;
 # endif
+#elif !defined __NR_signalfd4
+# error "__ASSUME_SIGNALFD4 defined but not __NR_signalfd4"
 #endif
 }