8082d91e1c
Many of the things defined by bits/signum.h are invariant across all supported operating systems. This patch factors out all of them to a new header bits/signum-generic.h, which each bits/signum.h will include and then override whichever things need adjustment. Normally that will mean, at most, adding or changing a few signal numbers. A user-visible side effect is that the obsolete signal constant SIGUNUSED (which is an alias for SIGSYS on all platforms that define it) is no longer exposed by any version of bits/signum.h. A side effect only relevant to glibc hackers is that _NSIG is now defined in terms of __SIGRTMAX, instead of the other way around. This is because __SIGRTMAX varies from platform to platform, but _NSIG==__SIGRTMAX+1 is true universally. If your platform doesn't support realtime signals, leave __SIGRTMAX equal to __SIGRTMIN. I also added a Linux-specific test to make sure that our signal constants match the ones in <asm/signal.h>, since we can't use that header (it's not even vaguely namespace-clean). * bits/signum-generic.h: Renamed from bits/signum.h. Add proper multiple include guard and misuse check. Define __SIGRTMIN = __SIGRTMAX = 32, and define _NSIG = __SIGRTMAX+1. Move definition of SIGIO to "archaic names for compatibility" section. * bits/signum.h: New file which just includes bits/signum-generic.h. * sysdeps/unix/bsd/bits/signum.h * sysdeps/unix/sysv/linux/bits/signum.h * sysdeps/unix/sysv/linux/alpha/bits/signum.h * sysdeps/unix/sysv/linux/hppa/bits/signum.h * sysdeps/unix/sysv/linux/mips/bits/signum.h * sysdeps/unix/sysv/linux/sparc/bits/signum.h Just include <bits/signum-generic.h> and then add or adjust signal constants. Do not define SIGUNUSED, SIGRTMIN, or SIGRTMAX. * signal/Makefile: Install bits/signum-generic.h. * signal/signal.h: Define SIGRTMIN and SIGRTMAX here. * sysdeps/generic/siglist.h: SIGSYS and SIGWINCH are universal. Prefer SIGPOLL to SIGIO. Simplify #ifdeffage. * sysdeps/unix/sysv/linux/tst-signal-numbers.sh: New test. * sysdeps/unix/sysv/linux/Makefile: Run it.
87 lines
2.7 KiB
Bash
87 lines
2.7 KiB
Bash
#! /bin/sh
|
|
# Test that glibc's signal numbers match the kernel's.
|
|
# Copyright (C) 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/>.
|
|
|
|
set -e
|
|
if [ -n "$BASH_VERSION" ]; then set -o pipefail; fi
|
|
LC_ALL=C; export LC_ALL
|
|
|
|
# We cannot use Linux's asm/signal.h to define signal numbers, because
|
|
# it isn't sufficiently namespace-clean. Instead, this test checks
|
|
# that our signal numbers match the kernel's. This script expects
|
|
# "$@" to be $(CC) $(CPPFLAGS) as set by glibc's Makefiles, and $AWK
|
|
# to be set in the environment.
|
|
|
|
# Before doing anything else, fail if the compiler doesn't work.
|
|
"$@" -E -xc -dM - < /dev/null > /dev/null
|
|
|
|
tmpG=`mktemp -t signums_glibc.XXXXXXXXX`
|
|
tmpK=`mktemp -t signums_kernel.XXXXXXXXX`
|
|
trap "rm -f '$tmpG' '$tmpK'" 0
|
|
|
|
# Filter out constants that aren't signal numbers.
|
|
# If SIGPOLL is defined as SIGIO, swap it around so SIGIO is defined as
|
|
# SIGPOLL. Similarly for SIGABRT and SIGIOT.
|
|
# Discard obsolete signal numbers and unrelated constants:
|
|
# SIGCLD, SIGIOT, SIGSWI, SIGUNUSED.
|
|
# SIGSTKSZ, SIGRTMIN, SIGRTMAX.
|
|
# Then sort the list.
|
|
filter_defines ()
|
|
{
|
|
$AWK '
|
|
/^#define SIG[A-Z]+ ([0-9]+|SIG[A-Z0-9]+)$/ { signals[$2] = $3 }
|
|
END {
|
|
if ("SIGPOLL" in signals && "SIGIO" in signals &&
|
|
signals["SIGPOLL"] == "SIGIO") {
|
|
signals["SIGPOLL"] = signals["SIGIO"]
|
|
signals["SIGIO"] = "SIGPOLL"
|
|
}
|
|
if ("SIGABRT" in signals && "SIGIOT" in signals &&
|
|
signals["SIGABRT"] == "SIGIOT") {
|
|
signals["SIGABRT"] = signals["SIGIOT"]
|
|
signals["SIGIOT"] = "SIGABRT"
|
|
}
|
|
for (sig in signals) {
|
|
if (sig !~ /^SIG(CLD|IOT|RT(MIN|MAX)|STKSZ|SWI|UNUSED)$/) {
|
|
printf("#define %s %s\n", sig, signals[sig])
|
|
}
|
|
}
|
|
}' | sort
|
|
}
|
|
|
|
# $CC may contain command-line switches, so it should be word-split.
|
|
printf '%s' '#define _GNU_SOURCE 1
|
|
#include <signal.h>
|
|
' |
|
|
"$@" -E -xc -dM - |
|
|
filter_defines > "$tmpG"
|
|
|
|
printf '%s' '#define _GNU_SOURCE 1
|
|
#define __ASSEMBLER__ 1
|
|
#include <asm/signal.h>
|
|
' |
|
|
"$@" -E -xc -dM - |
|
|
filter_defines > "$tmpK"
|
|
|
|
if cmp -s "$tmpG" "$tmpK"; then
|
|
exit 0
|
|
else
|
|
diff -u "$tmpG" "$tmpK"
|
|
exit 1
|
|
fi
|