mirror of
https://sourceware.org/git/glibc.git
synced 2024-12-26 12:41:05 +00:00
cd65836b5f
For XPG4.2, sa_sigaction, SA_ONSTACK, SA_RESETHAND, SA_RESTART and SA_NODEFER should be defined in signal.h, but they are only defined for other standards at present. This patch fixes the various bits/sigaction.h headers accordingly. All the fixes are essentially the same, except those for SPARC and Tile. For SPARC, the header (a) spuriously defined various nonstandard macros for __USE_UNIX98 || defined __USE_XOPEN2K8 and (b) defined some standard macros as aliases of nonstandard ones instead of the other way round. This patch fixes the SPARC header to handle these macros the same way and with the same conditions as those for other architectures, so the standard macros are the primary ones and the other ones are defined only for __USE_MISC and are aliases of the standard ones where applicable. For Tile, the header spuriously defined the nonstandard macro SA_NOPTRACE for __USE_UNIX98 || defined __USE_XOPEN2K8; this is moved to __USE_MISC. (Those nonstandard macros are in a reserved namespace, but it seems desirable to be consistent between architectures as far as possible, and so not define them in standard modes anywhere.) Tested for x86_64, and with build-many-glibcs.py. [BZ #21899] * bits/sigaction.h (struct sigaction): Define sa_handler and sa_sigaction using union also for [__USE_XOPEN_EXTENDED]. (SA_ONSTACK): Change [__USE_UNIX98] condition to [__USE_XOPEN_EXTENDED]. (SA_RESTART): Likewise. (SA_NODEFER): Likewise. (SA_RESETHAND): Likewise. * sysdeps/unix/sysv/linux/alpha/bits/sigaction.h (struct sigaction): Define sa_handler and sa_sigaction using union also for [__USE_XOPEN_EXTENDED]. (SA_ONSTACK): Change [__USE_UNIX98] condition to [__USE_XOPEN_EXTENDED]. (SA_RESTART): Likewise. (SA_NODEFER): Likewise. (SA_RESETHAND): Likewise. * sysdeps/unix/sysv/linux/bits/sigaction.h (struct sigaction): Define sa_handler and sa_sigaction using union also for [__USE_XOPEN_EXTENDED]. (SA_ONSTACK): Change [__USE_UNIX98] condition to [__USE_XOPEN_EXTENDED]. (SA_RESTART): Likewise. (SA_NODEFER): Likewise. (SA_RESETHAND): Likewise. * sysdeps/unix/sysv/linux/hppa/bits/sigaction.h (struct sigaction): Define sa_handler and sa_sigaction using union also for [__USE_XOPEN_EXTENDED]. (SA_ONSTACK): Change [__USE_UNIX98] condition to [__USE_XOPEN_EXTENDED]. (SA_RESTART): Likewise. (SA_NODEFER): Likewise. (SA_RESETHAND): Likewise. * sysdeps/unix/sysv/linux/ia64/bits/sigaction.h (struct sigaction): Define sa_handler and sa_sigaction using union also for [__USE_XOPEN_EXTENDED]. (SA_ONSTACK): Change [__USE_UNIX98] condition to [__USE_XOPEN_EXTENDED]. (SA_RESTART): Likewise. (SA_NODEFER): Likewise. (SA_RESETHAND): Likewise. * sysdeps/unix/sysv/linux/mips/bits/sigaction.h (struct sigaction): Define sa_handler and sa_sigaction using union also for [__USE_XOPEN_EXTENDED]. (SA_ONSTACK): Change [__USE_UNIX98] condition to [__USE_XOPEN_EXTENDED]. (SA_RESTART): Likewise. (SA_NODEFER): Likewise. (SA_RESETHAND): Likewise. * sysdeps/unix/sysv/linux/s390/bits/sigaction.h (struct sigaction): Define sa_handler and sa_sigaction using union also for [__USE_XOPEN_EXTENDED]. (SA_ONSTACK): Change [__USE_UNIX98] condition to [__USE_XOPEN_EXTENDED]. (SA_RESTART): Likewise. (SA_NODEFER): Likewise. (SA_RESETHAND): Likewise. * sysdeps/unix/sysv/linux/sparc/bits/sigaction.h (struct sigaction): Define sa_handler and sa_sigaction using union also for [__USE_XOPEN_EXTENDED]. (SA_ONSTACK): Change [__USE_UNIX98] condition to [__USE_XOPEN_EXTENDED]. (SA_RESTART): Likewise. (SA_NODEFER): Likewise. Define directly rather than as alias. (SA_RESETHAND): Likewise. (SA_INTERRUPT): Define only for [__USE_MISC]. (SA_NOMASK): Define as alias of SA_NODEFER, only for [__USE_MISC]. (SA_ONESHOT): Define as alias of SA_RESETHAND, only for [__USE_MISC]. (SA_STACK): Define only for [__USE_MISC]. * sysdeps/unix/sysv/linux/tile/bits/sigaction.h (struct sigaction): Define sa_handler and sa_sigaction using union also for [__USE_XOPEN_EXTENDED]. (SA_ONSTACK): Change [__USE_UNIX98] condition to [__USE_XOPEN_EXTENDED]. (SA_RESTART): Likewise. (SA_NODEFER): Likewise. (SA_RESETHAND): Likewise. (SA_NOPTRACE): Define only for [__USE_MISC].
80 lines
2.8 KiB
C
80 lines
2.8 KiB
C
/* Copyright (C) 1991-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/>. */
|
|
|
|
#ifndef _SIGNAL_H
|
|
# error "Never include <bits/sigaction.h> directly; use <signal.h> instead."
|
|
#endif
|
|
|
|
/* These definitions match those used by the 4.4 BSD kernel.
|
|
If the operating system has a `sigaction' system call that correctly
|
|
implements the POSIX.1 behavior, there should be a system-dependent
|
|
version of this file that defines `struct sigaction' and the `SA_*'
|
|
constants appropriately. */
|
|
|
|
/* Structure describing the action to be taken when a signal arrives. */
|
|
struct sigaction
|
|
{
|
|
/* Signal handler. */
|
|
#if defined __USE_POSIX199309 || defined __USE_XOPEN_EXTENDED
|
|
union
|
|
{
|
|
/* Used if SA_SIGINFO is not set. */
|
|
__sighandler_t sa_handler;
|
|
/* Used if SA_SIGINFO is set. */
|
|
void (*sa_sigaction) (int, siginfo_t *, void *);
|
|
}
|
|
__sigaction_handler;
|
|
# define sa_handler __sigaction_handler.sa_handler
|
|
# define sa_sigaction __sigaction_handler.sa_sigaction
|
|
#else
|
|
__sighandler_t sa_handler;
|
|
#endif
|
|
|
|
/* Additional set of signals to be blocked. */
|
|
__sigset_t sa_mask;
|
|
|
|
/* Special flags. */
|
|
int sa_flags;
|
|
};
|
|
|
|
/* Bits in `sa_flags'. */
|
|
#if defined __USE_XOPEN_EXTENDED || defined __USE_MISC
|
|
# define SA_ONSTACK 0x0001 /* Take signal on signal stack. */
|
|
#endif
|
|
#if defined __USE_XOPEN_EXTENDED || defined __USE_XOPEN2K8
|
|
# define SA_RESTART 0x0002 /* Restart syscall on signal return. */
|
|
# define SA_NODEFER 0x0010 /* Don't automatically block the signal when
|
|
its handler is being executed. */
|
|
# define SA_RESETHAND 0x0004 /* Reset to SIG_DFL on entry to handler. */
|
|
#endif
|
|
#define SA_NOCLDSTOP 0x0008 /* Don't send SIGCHLD when children stop. */
|
|
|
|
#ifdef __USE_MISC
|
|
# define SA_INTERRUPT 0 /* Historical no-op ("not SA_RESTART"). */
|
|
|
|
/* Some aliases for the SA_ constants. */
|
|
# define SA_NOMASK SA_NODEFER
|
|
# define SA_ONESHOT SA_RESETHAND
|
|
# define SA_STACK SA_ONSTACK
|
|
#endif
|
|
|
|
|
|
/* Values for the HOW argument to `sigprocmask'. */
|
|
#define SIG_BLOCK 1 /* Block signals. */
|
|
#define SIG_UNBLOCK 2 /* Unblock signals. */
|
|
#define SIG_SETMASK 3 /* Set the set of blocked signals. */
|