Rechercher une page de manuel
poll
Langue: fr
Version: 13 mars 2006 (mandriva - 01/05/08)
Section: 2 (Appels système)
Sommaire
NOM
poll, ppoll - Attendre un événement concernant un descripteur de fichierSYNOPSIS
#include <poll.h> int poll(struct pollfd *ufds, nfds_t nfds, int délai); int poll(struct pollfd *fds, nfds_t nfds, int délai); #define _GNU_SOURCE #include <poll.h> int ppoll(struct pollfd *fds, nfds_t nfds, const struct timespec *délai, const sigset_t *sigmask);
DESCRIPTION
poll() efectue une tâche similaire à select(2) : il attend que l'un des descripteurs de fichiers parmi un ensemble soit prêt pour effectuer des entrées-sorties.L'ensemble des descripteurs de fichiers à surveiller est spécifié dans l'argument fds qui est un tableau de structures nfds structures du type :
struct pollfd { int fd; /* Descripteur de fichier */ short events; /* Événements attendus */ short revents; /* Événements détectés */ };Le champ fd contient un descripteur de fichier ouvert. Le champ events est un paramètre d'entrée, un masque de bits indiquant les événements qui intéressent l'application. Le champ revents est un paramètre de sortie, rempli par le noyau avec les événements qui se sont effectivement produits. Les bits renvoyés dans revents peuvent inclure ceux spécifiés dans events, POLLERR, POLLHUP ou POLLNVAL. (Ces trois bits n'ont pas de signification dans la demande events, et se trouvent positionnés dans la valeur de retour revents si l'une des conditions correspondantes se produit).
Si aucun événement attendu (ni aucune erreur) ne s'est déjà produit, poll() bloquera jusqu'à ce que l'un des événements survienne. L'argument délai spécifie une limite haute, en millisecondes, sur le temps pendant lequel poll() bloquera. Spécifier une valeur ngative pour délai signifie un délai d'attente infini.
Les bits qui peuvent être positionnés/renvoyés dans events et revents sont définis dans <sys/poll.h> :
-
- POLLIN
- Il y a des données disponibles à la lecture.
- POLLPRI
- Il y a des données urgentes à lire (par exemple, ds données « hors bande » sur une socket TCP ; un pseudo terminal maître a vu l'esclave changer d'état).
- POLLOUT
- Une écriture ne bloquera pas.
- POLLRDHUP (depuis Linux 2.6.17)
- Le pair de la socket stream a fermé la connexion, ou a été mis hors service lors de l'écriture sur la connexion. La macro de test de fonctionnalité _GNU_SOURCE doit être définie pour obtenir cette définition.
- POLLERR
- Condition d'erreur (sortie seulement).
- POLLHUP
- Déconnexion (sortie seulement).
- POLLNVAL
- Requête invalide : fd n'est pas ouvert (sortie seulement).
Si on compile avec _XOPEN_SOURCE définie, on a également les choses suivantes, qui ne contient pas plus d'information que les bits précédents :
-
- POLLRDNORM
- Équivalent à POLLIN.
- POLLRDBAND
- Données prioritaires disponibles à la lecture (généralement pas utilisé sous Linux).
- POLLWRNORM
- Équivalent à POLLOUT.
- POLLWRBAND
- Écriture prioritaire possible.
Linux connait également POLLMSG mais ne l'utilise pas.
ppoll()
la relation entre poll() et ppoll() est analogue à la relation entre select(2) et pselect(2) : comme pselect(2), ppoll() permet à une application d'attendre sûrement que soit un descripteur de fichier devienne prêt, soit qu'un signal soit capturé.Outre la différence de l'argument délai, l'appel ppoll() suivant :
ready = ppoll(&fds, nfds, timeout, &sigmask);est équivalent à l'exécution atomique des appels suivants :
sigset_t origmask; sigprocmask(SIG_SETMASK, &sigmask, &origmask); ready = poll(&fds, nfds, timeout); sigprocmask(SIG_SETMASK, &origmask, NULL);
Voir la description de pselect(2) pour une explication sur pourquoi ppoll() est nécessaire.
L'argument timeout spécifie une limite haute sur le temps total pendant lequel ppoll() bloquera. Cet argument est un pointeur sur une structure de la forme :
struct timespec { long tv_sec; /* secondes */ long tv_nsec; /* nanosecondes */ };
Si timeout est spécifié comme NULL, bloquera indéfiniment.
VALEUR RENVOYÉE
S'il réussit, poll() renvoie une valeur positive représentant le nombre de structures ayant un champ revents non nul. C'est-à-dire le nombre de structures pour lesquels un événement attendu, ou une erreur, s'est produit. Une valeur de retour nulle indique un dépassement du délai d'attente et qu'aucun descripteur de fichier n'était prêt. S'il échoue, poll() renvoie -1, et errno contient le code d'erreur.ERREURS
- EBADF
- Un descripteur de fichier invalide est présent dans un ensemble.
- EFAULT
- La table fournie en argument n'est pas dans l'espace d'adressage du processus appelant.
- EINTR
- Un signal a été reçu avant qu'un événement intéressant ne se produise.
- EINVAL
- La valeur nfds dépasse la valeur RLIMIT_NOFILE.
- ENOMEM
- Pas assez de mémoire pour allouer la table des descripteurs de fichiers.
VERSIONS
L'appel système poll() a été introduit dans la version 2.1.23 du noyau Linux. La fonction de bibliothèque poll() est apparue dans la version 5.4.28 de la libc, et fournit une émulation basée sur l'appel système select(2) si le noyau n'a pas d'appel système poll().L'appel système a été ajouté à Linux dans le noyau 2.6.16. ppoll() a été ajouté à Linux dans le noyau 2.6.16. La fonction de bibliothèque ppoll() a été ajoutée dans la glibc 2.4
CONFORMITÉ
poll() est conforme à POSIX.1-2001. ppoll() est spécifique à Linux.NOTES
Certaines implémentations définissent une constante non standard INFTIM de valeur -1 à utiliser comme délai. Cette constante n'est pas fournie par la glibc.Notes Linux
L'appel système Linux ppoll() modifie son argument délai. Toutefois, la fonction enveloppe de la glibc cache ce comportement en utilisant une variable locale pour l'argument délai qui est passée à l'appel système. Ainsi, la fonction ppoll() de la glibc ne modifie pas son argument délai.BOGUES
Voir la section BOGUES de select(2).VOIR AUSSI
select(2) select_tut(2), feature_test_macros(7)TRADUCTION
Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 21 juillet 1997 et révisée le 24 novembre 2007.
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 poll ». N'hésitez pas à signaler à l'auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel.
Contenus ©2006-2024 Benjamin Poulain
Design ©2006-2024 Maxime Vantorre