| setitimer | |||
Nomgetitimer, setitimer - Lire / écrire la valeur d'une temporisation.Synopsis
DescriptionLe système fournit pour chaque processus trois temporisations, chacune avec un fonctionnement particulier. Lorsqu'une temporisation expire, un signal est envoyé au processus et la temporisation redémarre éventuellement.
Les valeurs des temporisations sont définies avec les structures suivantes :
Getitimer(2) renseigne la structure pointée par value avec le paramétrage de la temporisation which (parmi ITIMER_REAL, ITIMER_VIRTUAL, ou ITIMER_PROF). L'élément it_value est rempli avec le délai restant dans la temporisation, ou zéro si la temporisation est désactivée. De même it_interval sera rempli avec la valeur originale de la temporisation. Setitimer(2) positionne la temporisation avec les valeurs de value. Si ovalue est non nulle, les paramètres précédents de la temporisation y sont inscrits. Les temporisations décroissent de it_value à zéro, déclenchent un signal, et sont replacées à it_interval. Une temporisation s'arrête si elle est mise à zéro (it_value vaut zéro) ou bien elle expire et it_interval vaut zéro. Les deux champs tv_sec et tv_usec sont utilisés pour déterminer la durée d'une temporisation. Les temporisations n'expirent jamais avant la fin du temps requis, et expirent plutôt avec un délai court et constant après la limite. Ce délai dépend de la résolution du timer système (actuellement 10 ms). A l'expiration un signal est déclenché puis la temporisation réinitialisée. Si la temporisation expire alors que le processus est actif (toujours vrai avec ITIMER_VIRT) le signal sera délivré immédiatement. Autrement il y aura un petit délai avant réception du signal, dépendant de la charge du système.
Valeur Renvoyeégetitimer et setitimer renvoient 0 s'ils réussissent, ou -1 s'ils échouent, auquel cas errno contient le code d'erreur.Erreurs
ConformitéSVr4, 4.4BSD (Cet appel est apparu dans 4.2BSD).Voir Aussigettimeofday(2) , sigaction(2) , signal(2) .BoguesSous Linux, l'émission et la réception d'un signal sont distincts, et un même signal ne peut pas être émis deux fois de suite si le premier n'a pas été reçu. Il est ainsi possible qu'avec une charge système très élevée, une temporisation ITIMER_REAL expire avant que le signal d'une expiration précédente n'ait été reçu. Le second signal sera alors perdu.
TraductionChristophe Blaess, 1997.
|