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
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.
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() */
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.
Dernière mise à jour : 17 juillet 2008