sigpause(3) Library Functions Manual sigpause(3)

sigpause - schaltet gezielt blockierte Signale frei und wartet auf einen Interrupt

Standard-C-Bibliothek (libc, -lc)

ÜBERSICHT

#include <signal.h>
[[veraltet]] int sigpause(int sigmask);  /* BSD (siehe ANMERKUNGEN) */
[[veraltet]] int sigpause(int sig);      /* POSIX.1 / SysV / UNIX 95 */

Verwenden Sie diese nicht Funktion, sondern stattdessen sigsuspend(2).

Die Funktion sigpause() wurde entwickelt, um auf ein Signal warten. Sie ändert die Signalmaske (den Satz blockierter Signale) des Prozesses und wartet dann darauf, dass ein Signal eintrifft. Nach der Ankunft eines Signals wird die ursprüngliche Signalmaske wiederhergestellt.

Wenn sigpause() zurückkehrt, wurde sie durch ein Signal unterbrochen. Der Rückgabewert ist -1; der Wert von errno ist EINTR.

Siehe attributes(7) für eine Erläuterung der in diesem Abschnitt verwandten Ausdrücke.

Schnittstelle Attribut Wert
sigpause() Multithread-Fähigkeit MT-Sicher

Unter Linux ist diese Routine nur auf der Sparc-Architektur (sparc64) ein Systemaufruf.

Glibc verwendet die BSD-Version, wenn das Feature-Test-Makro _BSD_SOURCE und keines der Makros _POSIX_SOURCE, _POSIX_C_SOURCE, _XOPEN_SOURCE, _GNU_SOURCE oder _SVID_SOURCE definiert ist. Anderenfalls verwendet sie die System-V-Version und Feature-Test-Makros müssen wie folgt definiert sein, um die Deklarationen zu erhalten:

Seit Glibc 2.26: _XOPEN_SOURCE >= 500
Glibc 2.25 und älter: _XOPEN_SOURCE

Seit Glibc 2.19 wird nur die System-V-Version von <signal.h> angezeigt. Zu Anwendungen, die früher sigpause() von BSD verwendet haben, sollte sigsuspend(2) hinzugefügt werden.

POSIX.1-2008.

POSIX.1-2001. In POSIX.1-2008 als veraltet markiert.

Die klassische BSD-Version dieser Funktion erschien in 4.2BSD. Sie setzt die Signalmaske des Prozesses auf sigmask. UNIX 95 standardisierte die inkompatible System-V-Version dieser Funktion, die nur das angegebene Signal sig aus der Signalmaske des Prozesses entfernt. Die unglückliche Situation mit zwei unvereinbaren Funktionen mit dem gleichen Namen wurde von der Funktion sigsuspend(2) gelöst. Ihr Argument hat den Typ sigset_t * anstatt int.

kill(2), sigaction(2), sigprocmask(2), sigsuspend(2), sigblock(3), sigvec(3), feature_test_macros(7)

ÜBERSETZUNG

Die deutsche Übersetzung dieser Handbuchseite wurde von René Tschirley <gremlin@cs.tu-berlin.de>, Martin Eberhard Schauer <Martin.E.Schauer@gmx.de> und Mario Blättermann <mario.blaettermann@gmail.com> erstellt.

Diese Übersetzung ist Freie Dokumentation; lesen Sie die GNU General Public License Version 3 oder neuer bezüglich der Copyright-Bedingungen. Es wird KEINE HAFTUNG übernommen.

Wenn Sie Fehler in der Übersetzung dieser Handbuchseite finden, schicken Sie bitte eine E-Mail an die Mailingliste der Übersetzer.

2. Mai 2024 Linux man-pages 6.8