Man page - sigstack(3)

Packages contains this manual

Available languages:

en fr ja ru

Manual

sigaltstack

NOM
BIBLIOTHÈQUE
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
ERREURS
ATTRIBUTS
STANDARDS
HISTORIQUE
NOTES
Historique
BOGUES
EXEMPLES
VOIR AUSSI
TRADUCTION

NOM

sigaltstack - Consulter ou définir la pile de signal

BIBLIOTHÈQUE

BibliothĂšque C standard ( libc , -lc )

SYNOPSIS

#include <signal.h>

int sigaltstack(const stack_t *_Nullable restrict ss ,
stack_t *_Nullable restrict
old_ss );

Exigences de macros de test de fonctionnalités pour la glibc (consulter feature_test_macros (7)) :

sigaltstack () :
_XOPEN_SOURCE >= 500
|| /* Depuis la glibc 2.12 : */ _POSIX_C_SOURCE >= 200809L
|| /* glibc <= 2.19 : */ _BSD_SOURCE

DESCRIPTION

sigaltstack () permet Ă  un thread de dĂ©finir une nouvelle pile spĂ©cifique pour les gestionnaires de signaux et/ou de rĂ©cupĂ©rer l’état d’une pile spĂ©cifique de signal dĂ©jĂ  existante. Une pile spĂ©cifique de signal est utilisĂ©e durant l’exĂ©cution d’un gestionnaire de signal si la mise en place de ce gestionnaire (consultez sigaction (2)) le spĂ©cifiait.

La sĂ©quence d’actions nominale pour utiliser une pile spĂ©cifique de signal est la suivante :

1.

Allouer une zone mémoire qui sera utilisée comme pile spécifique de signal.

2.

Utiliser sigaltstack () afin d’informer le systĂšme de l’existence et de la position de la pile spĂ©cifique de signal.

3.

Lors de la mise en place du gestionnaire de signal en utilisant sigaction (2), informer le systĂšme que ce gestionnaire de signal doit ĂȘtre exĂ©cutĂ© sur la pile spĂ©cifique de signal en positionnant le drapeau SA_ONSTACK .

L’argument ss est utilisĂ© afin de dĂ©finir une nouvelle pile spĂ©cifique de signal, tandis que l’argument old_ss est utilisĂ© afin de rĂ©cupĂ©rer des informations sur la pile de signal actuellement en place. Si une seule de ces actions vous intĂ©resse, alors l’autre argument peut ĂȘtre positionnĂ© Ă  NULL.

Le type stack_t utilisé pour typer les paramÚtres de cette fonction est défini comme suit :

typedef struct {
void *ss_sp; /* Adresse de base de la pile*/
int ss_flags; /* Drapeaux */
size_t ss_size; /* Nombre d’octets dans la pile */
} stack_t;

Pour mettre en place une nouvelle pile de signal spécifique, les champs de cette structure sont définis comme suit :
ss.ss_flags

Ce champ contient soit 0 , soit le drapeau suivant :
SS_AUTODISARM
(depuis Linux 4.7)

Effacer les paramĂštres de la pile de signal spĂ©cifique lors de l’entrĂ©e dans le gestionnaire de signal. Au renvoi du gestionnaire de signal, les paramĂštres de la pile de signal spĂ©cifique seront restaurĂ©s.

Ce drapeau a Ă©tĂ© ajoutĂ© afin de sĂ©curiser la dĂ©sactivation d’un gestionnaire de signal avec swapcontext (3). Sans ce drapeau, un signal gĂ©rĂ© aprĂšs cette dĂ©sactivation corrompra l’état du gestionnaire de signal dĂ©sactivĂ©. Sur les noyaux oĂč ce drapeau n’est pas pris en charge, sigaltstack () Ă©choue avec l’erreur EINVAL quand ce drapeau est fourni.

ss.ss_sp

Ce champ indique l’adresse de dĂ©but de la pile. Lorsqu’un gestionnaire de signal est appelĂ© sur la pile spĂ©cifique, le noyau aligne automatiquement l’adresse donnĂ©e dans ss.ss_sp sur une valeur correcte pour l’architecture matĂ©rielle utilisĂ©e.

ss.ss_size

Ce champ spĂ©cifie l’adresse de la pile. La constante SIGSTKSZ est dĂ©finie de façon Ă  ĂȘtre suffisamment grande pour couvrir les besoins typiques en espace mĂ©moire d’une pile spĂ©cifique de signal, et la constante MINSIGSTKSZ dĂ©finit la taille minimale nĂ©cessaire Ă  l’exĂ©cution d’un gestionnaire de signal.

Afin de désactiver une pile existante, positionnez ss.ss_flags à SS_DISABLE . Dans ce cas, le noyau ignore tous les autres drapeaux de ss.ss_flags et les autres champs de ss .

Si old_ss ne vaut pas NULL, alors il est utilisĂ© afin de renvoyer des informations sur la pile spĂ©cifique de signal qui Ă©tait utilisĂ©e avant l’appel Ă  sigaltstack (). Les champs old_ss.ss_sp et old_ss.ss_size renvoient l’adresse de dĂ©part et la taille de cette pile. Le champ old_ss.ss_flags peut renvoyer l’une des valeurs suivantes :
SS_ONSTACK

Le thread s’exĂ©cute actuellement sur la pile spĂ©cifique de signal. (Remarquez qu’il n’est pas possible de changer la pile spĂ©cifique de signal si le thread est en train de s’exĂ©cuter sur cette derniĂšre.)

SS_DISABLE

La pile spécifique de signal est actuellement désactivée.

Sinon, cette valeur est renvoyĂ©e si le processus s’exĂ©cute actuellement sur une pile de signal spĂ©cifique mise en place en utilisant le drapeau SS_AUTODISARM . Dans ce cas, il est plus sĂ»r de dĂ©sactiver le gestionnaire de signal avec swapcontext (3). Il est Ă©galement possible de dĂ©finir une autre pile spĂ©cifique en utilisant un autre appel sigaltstack ().

SS_AUTODISARM

La pile spĂ©cifique de signal a Ă©tĂ© marquĂ©e pour ĂȘtre dĂ©sactivĂ©e comme dĂ©crit ci-dessus.

En positionnant ss sur NULL et old_ss sur une valeur autre que NULL, on peut obtenir les paramÚtres de la pile de signal spécifique sans les modifier.

VALEUR RENVOYÉE

sigaltstack () renvoie 0 en cas de succĂšs, ou -1 en cas d’échec en positionnant alors errno pour prĂ©ciser l’erreur.

ERREURS

EFAULT

Un des paramĂštres ss ou old_ss ne vaut pas NULL et pointe vers une zone mĂ©moire n’appartenant pas Ă  l’espace d’adressage du processus.

EINVAL

ss ne vaut pas NULL et le champ ss_flags contient une valeur non valable.

ENOMEM

La taille de la nouvelle pile spécifique de signal indiquée ( ss.ss_size ) est inférieure à MINSIGSTKSZ .

EPERM

On a essayĂ© de modifier la pile spĂ©cifique de signal alors que celle-ci Ă©tait active (c’est-Ă -dire, le thread Ă©tait dĂ©jĂ  en train de s’exĂ©cuter sur la pile spĂ©cifique de signal courante).

ATTRIBUTS

Pour une explication des termes utilisés dans cette section, consulter attributes (7).

Image grohtml-3892594-1.png

STANDARDS

POSIX.1-2008.

SS_AUTODISARM est une extension de Linux.

HISTORIQUE

POSIX.1-2001, SUSv2, SVr4.

NOTES

Le cas le plus courant d’utilisation d’une pile spĂ©cifique est pour la gestion du signal SIGSEGV qui est gĂ©nĂ©rĂ© si la place disponible pour la pile normale est Ă©puisĂ©e. Dans ce cas, un gestionnaire pour SIGSEGV ne peut pas ĂȘtre exĂ©cutĂ© sur la pile standard ; si l’on souhaite l’intercepter, on doit utiliser une pile spĂ©cifique.

La mise en place d’une pile spĂ©cifique de signal est utile si un thread soupçonne qu’il est susceptible d’épuiser sa pile standard. Cela peut se produire, par exemple, lorsque la pile grossit au point de rencontrer la limite supĂ©rieure du tas, ou si elle atteint une limite Ă©tablie par un appel Ă  setrlimit(RLIMIT_STACK, &rlim) . Si la pile standard est Ă©puisĂ©e, le noyau envoie au processus un signal SIGSEGV . Dans ces circonstances, la seule façon d’intercepter ce signal est d’utiliser une pile spĂ©cifique de signal.

Sur la plupart des architectures supportĂ©es par Linux, les piles s’étendent vers les adresses dĂ©croissantes. sigaltstack () prend automatiquement en charge le sens d’expansion de la pile.

Les fonctions appelĂ©es depuis un gestionnaire de signal s’exĂ©cutant sur une pile spĂ©cifique de signal utilisent Ă©galement cette pile. (Cela s’applique Ă©galement Ă  tous les gestionnaires invoquĂ©s pour d’autres signaux alors que le thread s’exĂ©cute sur la pile spĂ©cifique de signal.) Contrairement Ă  la pile standard, le systĂšme n’accroĂźt pas automatiquement la pile spĂ©cifique de signal. DĂ©passer la taille allouĂ©e pour la pile spĂ©cifique de signal conduit Ă  des rĂ©sultats imprĂ©visibles.

Un appel execve (2) rĂ©ussi supprime toutes les piles de signal spĂ©cifiques. Un processus enfant créé Ă  l’aide de fork (2) hĂ©rite d’une copie des paramĂštres de la pile de signal spĂ©cifique de son parent. Cela vaut aussi pour un processus enfant créé avec clone (2), sauf si les drapeaux de clone incluent CLONE_VM et n’incluent pas CLONE_VFORK , auquel cas toutes les piles de signal spĂ©cifique mises en place dans le processus parent sont dĂ©sactivĂ©es dans le processus enfant.

sigaltstack () succĂšde Ă  l’ancien appel sigstack (). Pour des raisons de compatibilitĂ©, la glibc implĂ©mente sigstack (). Toutes les nouvelles applications devraient ĂȘtre Ă©crites en utilisant sigaltstack ().

Historique

BSD 4.2 possĂ©dait un appel systĂšme sigstack (). Il utilisait une structure lĂ©gĂšrement diffĂ©rente, et avait comme dĂ©savantage principal la nĂ©cessitĂ© pour l’appelant de connaĂźtre le sens d’expansion de la pile.

BOGUES

Dans Linux 2.2, le seul drapeau qui pouvait ĂȘtre indiquĂ© dans ss.sa_flags Ă©tait SS_DISABLE . À partir de la publication du noyau Linux 2.4, un changement a Ă©tĂ© apportĂ© pour permettre Ă  sigaltstack () d’autoriser ss.ss_flags==SS_ONSTACK Ă  avoir le mĂȘme sens que ss.ss_flags==0 (Ă  savoir que l’inclusion de SS_ONSTACK dans ss.ss_flags est une non-op). Sur d’autres implĂ©mentations et selon POSIX.1, SS_ONSTACK n’apparaĂźt que comme un drapeau signalĂ© dans old_ss.ss_flags . Sur Linux, il n’y a mĂȘme pas besoin d’indiquer SS_ONSTACK dans ss.ss_flags , et en effet, vous devriez Ă©viter de le faire pour des raisons de portabilité : plusieurs autres systĂšmes donnent une erreur si SS_ONSTACK est indiquĂ© dans ss.ss_flags .

EXEMPLES

Le bout de code suivant montre l’utilisation de sigaltstack () (et de sigaction (2)) pour installer une pile de signal spĂ©cifique utilisĂ©e par le gestionnaire pour le signal SIGSEGV :

stack_t ss;
ss.ss_sp = malloc(SIGSTKSZ);
if (ss.ss_sp == NULL) {
perror("malloc");
exit(EXIT_FAILURE);
}
ss.ss_size = SIGSTKSZ;
ss.ss_flags = 0;
if (sigaltstack(&ss, NULL) == -1) {
perror("sigaltstack");
exit(EXIT_FAILURE);
}
sa.sa_flags = SA_ONSTACK;
sa.sa_handler = handler(); /* Adresse d’un gestionnaire de signal */
sigemptyset(&sa.sa_mask);
if (sigaction(SIGSEGV, &sa, NULL) == -1) {
perror("sigaction");
exit(EXIT_FAILURE);
}

VOIR AUSSI

execve (2), setrlimit (2), sigaction (2), siglongjmp (3), sigsetjmp (3), signal (7)

TRADUCTION

La traduction française de cette page de manuel a été créée par Christophe Blaess <https://www.blaess.fr/christophe/>, Stéphan Rafin <stephan.rafin@laposte.net>, Thierry Vignaud <tvignaud@mandriva.com>, François Micaux, Alain Portal <aportal@univ-montp2.fr>, Jean-Philippe Guérard <fevrier@tigreraye.org>, Jean-Luc Coulon (f5ibh) <jean-luc.coulon@wanadoo.fr>, Julien Cristau <jcristau@debian.org>, Thomas Huriaux <thomas.huriaux@gmail.com>, Nicolas François <nicolas.francois@centraliens.net>, Florentin Duneau <fduneau@gmail.com>, Simon Paillard <simon.paillard@resel.enst-bretagne.fr>, Denis Barbier <barbier@debian.org>, David Prévot <david@tilapin.org>, Cédric Boutillier <cedric.boutillier@gmail.com>, Frédéric Hantrais <fhantrais@gmail.com> et Jean-Philippe MENGUAL <jpmengual@debian.org>

Cette traduction est une documentation libre ; veuillez vous reporter à la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n’y a aucune RESPONSABILITÉ LÉGALE.

Si vous découvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message à debian-l10n-french@lists.debian.org .