SIGQUEUE

Section : Manuel du programmeur Linux (2)
Mise à jour de la version anglaise : 26 juillet 2007
Index Menu principal  

NOM

sigqueue, rt_sigqueueinfo - Enregistrer un signal et des données pour un processus  

SYNOPSIS

#include <signal.h>

int sigqueue(pid_t pid, int sig, const union sigval valeur);

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

sigqueue() : _POSIX_C_SOURCE >= 199309L  

DESCRIPTION

sigqueue() envoie le signal sig au processus indiqué par pid. Les permissions requises pour l'émission du signal sont les mêmes que pour kill(2). Comme avec kill(2), le signal nul (0) peut servir à vérifier si un processus existe avec un PID donné.

L'argument valeur sert à indiquer une donnée (soit un entier, soit un pointeur) qui accompagnera le signal et se présente avec le type suivant :

union sigval {
    int   sival_int;
    void *sival_ptr;
};

Si le processus récepteur a installé un gestionnaire pour le signal avec l'option SA_SIGINFO lors du sigaction(2), il pourra obtenir la donnée dans le champ si_value de la structure siginfo_t passée en second argument au gestionnaire. De plus, le champ si_code de la structure contiendra SI_QUEUE.  

VALEUR RENVOYÉE

L'appel sigqueue() renvoie 0 s'il réussit, indiquant que le signal a bien été mis dans la file du processus récepteur. Sinon il renvoie -1 et errno contient le code de l'erreur.  

ERREURS

EAGAIN
La limite du nombre de signaux en file a été atteinte. (Voir signal(7) pour plus d'informations).
EINVAL
sig est invalide.
EPERM
Le processus n'a pas la permission d'envoyer un signal au processus visé. Pour les permissions nécessaires, voir kill(2).
ESRCH
Il n'y a pas de processus correspondant au pid.
 

VERSIONS

Cet appel système a été introduit dans Linux 2.2.  

CONFORMITÉ

POSIX.1-2001.  

NOTES

Si l'appel consiste à envoyer un signal au processus qui l'a invoqué, et si le signal n'est pas bloqué par le thread appelant, et si aucun autre thread ne peut traiter le signal (soit en l'ayant débloqué, ou en faisant une attente avec sigwait(3)), alors au moins quelques signaux seront délivrés au thread appelant avant que la fonction ne revienne.

Sous Linux, l'appel système sous-jacent s'appelle en fait rt_sigqueueinfo(), et diffère dans son troisième argument qui est une structure siginfo_t qui sera fournie au gestionnaire de signal du processus récepteur ou renvoyée par l'appel sigtimedwait(2) du processus récepteur. Dans l'enveloppe sigqueue() de la glibc, cet argument info, est initialisé de la manière suivante :


info.si_signo = sig;      /* argument fourni à sigqueue() */
info.si_code = SI_QUEUE;
info.si_pid = getpid();   /* PID de l'envoyeur */
info.si_uid = getuid();   /* UID réel de l'envoyeur */
info.si_value = val;      /* argument fourni à sigqueue() */
 

VOIR AUSSI

kill(2), sigaction(2), signal(2), sigwait(3), signal(7)  

TRADUCTION

Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 18 juillet 2003 et révisée le 17 juillet 2008.

L'équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=C man 2 sigqueue ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.

 

Index

NOM
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
ERREURS
VERSIONS
CONFORMITÉ
NOTES
VOIR AUSSI
TRADUCTION

Dernière mise à jour : 17 juillet 2008