sigqueue   Début   Suivant   Sommaire   Préc.page.lue   Accueil
Section: Manuel du programmeur Linux (2)
Updated: 26 juillet 2007
Sommaire  



NOM   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
sigqueue, rt_sigqueueinfo - Enregistrer un signal et des données pour un processus  



SYNOPSIS   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
#include <signal.h>

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

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

sigqueue() : _POSIX_C_SOURCE >= 199309L  




DESCRIPTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
sigqueue() envoie le signal sig au processus indiqué par pid. Les permissions requises pour l'émission du signal sont les même 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   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
L'appel sigqueue() renvoie 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   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
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   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
Cet appel système a été introduit dans Linux 2.2.  



CONFORMITÉ   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
POSIX.1-2001  



NOTES   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
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 signaux 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   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil
kill(2), sigaction(2), signal(2), sigwait(3), signal(7)  



TRADUCTION   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

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 6 juin 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.


 



Sommaire   Début   Suivant   Sommaire   Préc.page.lue   Accueil
NOM
SYNOPSIS
DESCRIPTION
VALEUR RENVOYÉE
ERREURS
VERSIONS
CONFORMITÉ
NOTES
VOIR AUSSI
TRADUCTION

Table des mots clés   Début   Suivant   Sommaire   Préc.page.lue   Accueil
EAGAINERREURS
EINVALERREURS
EPERMERREURS
ESRCHERREURS



Ce document a été créé par man2html suivi de man2html.pl, le 17/10/2008 17:51:15, en utilisant les pages de 'man'.
 

Valid HTML 4.01 Transitional