time   Début   Suivant   Sommaire   Préc.page.lue   Accueil

Section: Manuel du programmeur Linux (7)
Updated: 25 juin 2008
Sommaire  




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

time - Panorama des fonctions liées au temps et aux temporisations  




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

 




Temps réel et temps processus   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

Le temps réel est défini comme étant le temps mesuré à partir d'un instant fixé : soit un instant standard du passé (voir la description de l'Époque et du temps calendrier plus loin), soit un instant (par exemple, le début) de la vie d'un processus (temps écoulé).

Le temps processus est défini comme le temps CPU consommé par un processus.

Il est parfois divisé en deux parties : le temps utilisateur et le temps système. Le temps CPU utilisateur est le temps passé à exécuter du code en mode utilisateur. Le temps CPU système est le temps passé par le noyau à exécuter en mode système au nom du processus (par exemple, exécuter les appels système). La commande time(1) peut être utilisée pour déterminer le temps CPU consommé pendant l'exécution d'un programme. Un programme peut déterminer le temps CPU qu'il a consommé en utilisant times(2), getrusage(2) ou clock(3).  




L'horloge matérielle   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

La plupart des ordinateurs ont une horloge matérielle (alimentée par pile) que le noyau lit au démarrage afin d'initialiser l'horloge logicielle. Pour plus de détails, voir rtc(4) et hwclock(8).  




L'horloge logicielle, HZ, et jiffies   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

La précision de divers appels système qui définissent des délais (par exemple select(2), sigtimedwait(2)) ou qui mesurent le temps processeur (par exemple getrusage(2)) est limitée par la résolution de l'horloge logicielle, une horloge maintenue par le noyau qui mesure le temps en jiffies. La taille d'un jiffy est déterminée par la valeur de la constante noyau HZ.

La valeur de HZ varie suivant les versions du noyau et des plates-formes matérielles.

Sur i386, la situation est la suivante : pour les noyaux jusqu'au 2.4.x inclus, HZ vaut 100, ce qui donne une valeur de jiffy de 10 millisecondes ; à partir du noyau 2.6.0, HZ a été augmenté à 1000, donnant un jiffy d'une millisecondes.

Depuis le noyau 2.6.13, la valeur de HZ est un paramètre de configuration du noyau qui peut valoir 100, 250 (valeur par défaut) ou 1000, donnant des valeurs de, respectivement, 10, 4 ou 1 millisecondes pour un jiffy. Depuis le noyau 2.6.20, une autre fréquence est disponible : 300, un diviseur pour les taux de rafraichissement vidéo classiques (PAL, 25 Hz ; NTSC, 30 Hz).

L'appel système times(2) est un cas particulier. Il renvoie le temps avec une granularité définie par la constante du noyau USER_HZ. Les applications utilisateur peuvent obtenir la valeur de cette constante avec sysconf(_SC_CLK_TCK).  




Temporisations haute résolution   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

Avant Linux 2.6.21, la précision des appels système gérant les temporisations et les sommeils (voir plus loin) était limitée par la taille du « jiff ».

Depuis la version 2.6.21, Linux gère les temporisations haute résolution (HRT : high-resolution timers) de manière optionnelle en configurant CONFIG_HIGH_RES_TIMERS. Sur les systèmes gérant les temporisations haute résolution, la précision des appels système gérant les temporisations et les sommeils n'est plus limitée par le « jiffy » et peut être aussi fine que le système ne le permette (une précision d'une microseconde est typique sur les matériels actuels). Vous pouvez savoir si les temporisations haute résolution sont gérées en vérifiant la précision renvoyée par un appel à clock_getres(3) ou en regardant les entrées « resolution » du fichier /proc/timer_list.

Les temporisations haute résolution ne sont pas gérées par toutes les architectures matérielles.

Cette gestion est disponible sur x86, arm et powerpcparmi d'autres.

 




L'Époque   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

Les systèmes Unix représentent le temps en secondes depuis l'Époque, qui est définie comme étant le 1er janvier 1970 à 0:00:00 UTC.

Un programme peut déterminer le temps calendrier en utilisant gettimeofday(2), qui renvoie le temps (en secondes et microsecondes) qui s'est écoulé depuis l'Époque ; time(2) fournit une information similaire, mais seulement avec une précision de la seconde la plus proche. Le temps système peut être modifié avec settimeofday(2).  




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

Certaines fonctions de la bibliothèque utilisent une structure de type tm pour représenter le temps ventilé, qui stocke la valeur du temps en des composantes distinctes (année, mois, jour, heure, minute, seconde, etc.). Cette structure structure est décrite dans ctime(3), qui décrit également les fonctions qui convertissent le temps calendrier en temps ventilé et vice versa. Les fonctions pour convertir le temps ventilé en chaîne de caractères affichables sont décrites dans ctime(3), strftime(3) et strptime(3).  




Sommeil et configuration des temporisations   Début   Précédent   Suivant   Sommaire   Préc.page.lue   Accueil

Divers appels système et fonctions permettent à un programme de s'endormir (suspendre son exécution) pour une durée spécifiée ; voir nanosleep(2), clock_nanosleep(2) et sleep(3).

Divers appels système permettent à un processus de configurer une temporisation qui expirera à un moment particulier dans le futur, et optionnellement à intervalles réguliers ; voir alarm(2), getitimer(2), timerfd_create(2) et timer_create(3).  




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

date(1), time(1), adjtimex(2), alarm(2), clock_nanosleep(2), getitimer(2), getrlimit(2), getrusage(2), gettimeofday(2), nanosleep(2), stat(2), time(2), timerfd_create(2), times(2), utime(2), adjtime(3), clock(3), ctime(3), sleep(3), strftime(3), strptime(3), timeradd(3), usleep(3), rtc(4), hwclock(8)  




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

Ce document est une traduction réalisée par Alain Portal <aportal AT univ-montp2 DOT fr> le 4 août 2006 et révisée le 2 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 7 time ». 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

DESCRIPTION

Temps réel et temps processus

L'horloge matérielle

L'horloge logicielle, HZ, et jiffies

Temporisations haute résolution

L'Époque

Temps ventilé

Sommeil et configuration des temporisations

VOIR AUSSI

TRADUCTION


Ce document a été créé par man2html suivi de man2html.pl, le 27/10/2008 08:42:31, en utilisant les pages de 'man'.
 

Valid HTML 4.01 Transitional