mirror of
https://sourceware.org/git/glibc.git
synced 2025-05-30 04:04:54 +03:00
sigprocmask.c, sigtimedwait.c, sigwait.c and sigwaitinfo.c files from sysdeps/unix/sysv/linux include nptl-signals.h via nptl/pthreadP.h, and so SIGCANCEL and SIGSETXID become defined unconditionally. But later in the code, there are some checks weither symbols defined, which is useless. This patch removes useless checks. Checked on x86_64-linux-gnu. * sysdeps/unix/sysv/linux/sigprocmask.c: Remove useless #ifdefs. * sysdeps/unix/sysv/linux/sigtimedwait.c: Likewise. * sysdeps/unix/sysv/linux/sigwait.c: Likewise. * sysdeps/unix/sysv/linux/sigwaitinfo.c: Likewise. Signed-off-by: Yury Norov <ynorov@caviumnetworks.com> Reviewed-by: Andreas Schwab <schwab@suse.de> Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
67 lines
2.2 KiB
C
67 lines
2.2 KiB
C
/* Copyright (C) 1997-2017 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
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2.1 of the License, or (at your option) any later version.
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with the GNU C Library; if not, see
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
#include <errno.h>
|
|
#include <signal.h>
|
|
#define __need_NULL
|
|
#include <stddef.h>
|
|
#include <string.h>
|
|
|
|
#include <nptl/pthreadP.h>
|
|
#include <sysdep-cancel.h>
|
|
#include <sys/syscall.h>
|
|
|
|
#ifdef __NR_rt_sigtimedwait
|
|
|
|
/* Return any pending signal or wait for one for the given time. */
|
|
int
|
|
__sigwaitinfo (const sigset_t *set, siginfo_t *info)
|
|
{
|
|
sigset_t tmpset;
|
|
if (set != NULL
|
|
&& (__builtin_expect (__sigismember (set, SIGCANCEL), 0)
|
|
|| __builtin_expect (__sigismember (set, SIGSETXID), 0)))
|
|
{
|
|
/* Create a temporary mask without the bit for SIGCANCEL set. */
|
|
// We are not copying more than we have to.
|
|
memcpy (&tmpset, set, _NSIG / 8);
|
|
__sigdelset (&tmpset, SIGCANCEL);
|
|
__sigdelset (&tmpset, SIGSETXID);
|
|
set = &tmpset;
|
|
}
|
|
|
|
/* XXX The size argument hopefully will have to be changed to the
|
|
real size of the user-level sigset_t. */
|
|
int result = SYSCALL_CANCEL (rt_sigtimedwait, set, info, NULL, _NSIG / 8);
|
|
|
|
/* The kernel generates a SI_TKILL code in si_code in case tkill is
|
|
used. tkill is transparently used in raise(). Since having
|
|
SI_TKILL as a code is useful in general we fold the results
|
|
here. */
|
|
if (result != -1 && info != NULL && info->si_code == SI_TKILL)
|
|
info->si_code = SI_USER;
|
|
|
|
return result;
|
|
}
|
|
|
|
libc_hidden_def (__sigwaitinfo)
|
|
weak_alias (__sigwaitinfo, sigwaitinfo)
|
|
#else
|
|
# include <signal/sigwaitinfo.c>
|
|
#endif
|
|
strong_alias (__sigwaitinfo, __libc_sigwaitinfo)
|