diff options
author | H.J. Lu <hjl.tools@gmail.com> | 2015-08-21 09:57:15 -0700 |
---|---|---|
committer | H.J. Lu <hjl.tools@gmail.com> | 2015-08-21 09:57:15 -0700 |
commit | e5dee2c896f04d88defdfa00282fa83f5f4004d8 (patch) | |
tree | caebcffacffc0363dc418694eba18b2ce6b8617b /sysdeps/unix/sysv/linux/signalfd.c | |
parent | 8c7c251746ce41779637c83e3b35639517f728d5 (diff) | |
download | glibc-e5dee2c896f04d88defdfa00282fa83f5f4004d8.tar glibc-e5dee2c896f04d88defdfa00282fa83f5f4004d8.tar.gz glibc-e5dee2c896f04d88defdfa00282fa83f5f4004d8.tar.bz2 glibc-e5dee2c896f04d88defdfa00282fa83f5f4004d8.zip |
Revert "Add INLINE_SYSCALL_RETURN/INLINE_SYSCALL_ERROR_RETURN"
This reverts commit 0c5b8b5941e036dcaac69cecee9f01fdf9218e6e.
Diffstat (limited to 'sysdeps/unix/sysv/linux/signalfd.c')
-rw-r--r-- | sysdeps/unix/sysv/linux/signalfd.c | 22 |
1 files changed, 10 insertions, 12 deletions
diff --git a/sysdeps/unix/sysv/linux/signalfd.c b/sysdeps/unix/sysv/linux/signalfd.c index e07b56cf06..f3ae8c1947 100644 --- a/sysdeps/unix/sysv/linux/signalfd.c +++ b/sysdeps/unix/sysv/linux/signalfd.c @@ -26,17 +26,11 @@ int signalfd (int fd, const sigset_t *mask, int flags) { #ifdef __NR_signalfd4 + int res = INLINE_SYSCALL (signalfd4, 4, fd, mask, _NSIG / 8, flags); # ifndef __ASSUME_SIGNALFD4 - INTERNAL_SYSCALL_DECL (err); - int res = INTERNAL_SYSCALL (signalfd4, err, 4, fd, mask, _NSIG / 8, - flags); - if (!__glibc_unlikely (INTERNAL_SYSCALL_ERROR_P (res, err)) - || INTERNAL_SYSCALL_ERRNO (res, err) != ENOSYS) - return res; -# else - return INLINE_SYSCALL_RETURN (signalfd4, 4, int, fd, mask, _NSIG / 8, - flags); + if (res != -1 || errno != ENOSYS) # endif + return res; #endif #ifndef __ASSUME_SIGNALFD4 @@ -45,12 +39,16 @@ signalfd (int fd, const sigset_t *mask, int flags) kernel (sys_indirect) before implementing setting flags like O_NONBLOCK etc. */ if (flags != 0) - return INLINE_SYSCALL_ERROR_RETURN (-EINVAL, int, -1); + { + __set_errno (EINVAL); + return -1; + } # ifdef __NR_signalfd - return INLINE_SYSCALL_RETURN (signalfd, 3, int, fd, mask, _NSIG / 8); + return INLINE_SYSCALL (signalfd, 3, fd, mask, _NSIG / 8); # else - return INLINE_SYSCALL_ERROR_RETURN (-ENOSYS, int, -1); + __set_errno (ENOSYS); + return -1; # endif #elif !defined __NR_signalfd4 # error "__ASSUME_SIGNALFD4 defined but not __NR_signalfd4" |