Provided by: manpages-fr-dev_4.13-4_all bug

NOM

       gettimeofday, settimeofday - Lire/écrire l'heure actuelle

SYNOPSIS

       #include <sys/time.h>

       int gettimeofday(struct timeval *tv, struct timezone *tz);

       int settimeofday(const struct timeval *tv, const struct timezone *tz);

   Exigences de macros de test de fonctionnalités pour la glibc (consulter feature_test_macros(7)) :

       settimeofday() :
            Depuis la glibc 2.19 :
               _DEFAULT_SOURCE
            Pour la gilbc 2.19 et antérieures :
               _BSD_SOURCE

DESCRIPTION

       Les  fonctions  gettimeofday() et settimeofday() servent à lire ou programmer l'heure ainsi que le fuseau
       horaire (timezone).

       L'argument tv est une structure timeval (comme indiqué dans <sys/time.h>) :

           struct timeval {
               time_t      tv_sec;     /* secondes */
               suseconds_t tv_usec;    /* microsecondes */
           };

       et donne le nombre de secondes et microsecondes écoulées depuis l'epoch (consultez time(2)).

       L'argument tz est une structure timezone :

           struct timezone {
               int tz_minuteswest; /* minutes à l'ouest de Greenwich   */
               int tz_dsttime;     /* type de changement d’heure d’été */
           };

       Si tv ou tz est NULL,  la  structure  correspondante  n'est  ni  remplie  ni  renvoyée.  (Cependant,  des
       avertissements à la compilation seront émis si tv est NULL.)

       L'utilisation  de  la  structure  timezone  est  obsolète ;  le  paramètre tz doit normalement être NULL.
       Consultez la section NOTES ci-dessous.

       Sous Linux, il existe une sémantique particulière associée à l'appel système settimeofday() si durant  la
       première  invocation  (après l’amorçage) il a un argument tz non NULL, l'argument tv est NULL et le champ
       tz_minuteswest est différent de zéro (dans ce cas, le champ tz_dsttime doit être nul). Dans  ce  cas,  on
       suppose  que l'horloge CMOS de la machine est configurée sur l'heure locale, et qu'on doit l'augmenter de
       cette valeur pour obtenir l'heure UTC. Bien entendu, il faut éviter autant que possible d'utiliser  cette
       particularité.

VALEUR RENVOYÉE

       gettimeofday  et  settimeofday  renvoient  0  s'ils  réussissent,  ou -1 s'ils échouent, auquel cas errno
       contient le code d'erreur.

ERREURS

       EFAULT tv ou tz pointent en dehors de l'espace d'adressage autorisé.

       EINVAL (settimeofday()) : timezone n'est pas valable.

       EINVAL (settimeofday()) : tv.tv_sec est négatif ou tv.tv_usec dépasse l'intervalle 0-999999.

       EINVAL (depuis Linux 4.3)
              (settimeofday()) : tentative de positionner l'heure sur une valeur inférieure à  l'heure  actuelle
              de l'horloge CLOCK_MONOTONIC (voir clock_gettime(2)).

       EPERM  Le  processus appelant n'a pas les privilèges suffisants pour appeler settimeofday() ; sous Linux,
              la capacité CAP_SYS_TIME est nécessaire.

CONFORMITÉ

       SVr4,  4.3BSD.  POSIX.1-2001  décrit  gettimeofday()  mais  pas   settimeofday().   POSIX.1-2008   marque
       gettimeofday() comme étant obsolète, en recommandant d'utiliser clock_gettime(2) à la place.

NOTES

       L'heure  renvoyée  par  gettimeofday()  est  concernée  par  les  sauts  discontinus  de  l'heure système
       (c'est-à-dire si l'administrateur modifie l'heure système lui-même). Si vous devez incrémenter  l'horloge
       de façon monotone, consultez clock_gettime(2).

       Les macros opérant sur les structures timeval sont décrites dans timeradd(3).

       Traditionnellement, les champs de la structure timeval étaient de type long.

   différences entre bibliothèque C et noyau
       Sur certaines architectures, une implémentation de gettimeofday() est fournie dans vdso(7).

   Le champ tz_dsttime
       Sur  un  noyau non Linux, avec la glibc, le champ tz_dsttime de la structure timezone sera positionné sur
       une valeur non nulle par gettimeofday() si il a été appliqué ou sera appliqué au  fuseau  horaire  actuel
       une  règle  de  sauvegarde  d’heure  d’été.  Dans  ce  sens,  elle reflète exactement la signification de
       daylight(3) pour la zone actuelle. Sur Linux avec la glibc, le positionnement du champ tz_dsttime  de  la
       structure  timezone  n'a  jamais été utilisé par settimeofday() ou gettimeofday(). Ainsi, ce qui suit n'a
       qu'un intérêt historique.

       Sur d'anciens systèmes, le champ tz_dsttime contient une constante  symbolique  (dont  les  valeurs  sont
       fournies  ci‐dessous)  qui  indique  quelle  partie  du  changement  d’heure  d’été  annuel est en cours.
       (Remarque : cette valeur est constante tout au long de l'année, elle n'indique pas réellement  la  valeur
       que  cette  heure  d’été  est  en  cours,  elle sélectionne un algorithme). Les changements d’heure d’été
       (Daylight Saving Time - DST) sont définis comme suit :

           DST_NONE     /* pas sur DST */
           DST_USA      /* DST à l'américaine */
           DST_AUST     /* DST à l'australienne */
           DST_WET      /* DST d'Europe occidentale */
           DST_MET      /* DST d'Europe centrale */
           DST_EET      /* DST d'Europe de l'Est */
           DST_CAN      /* Canada */
           DST_GB       /* Grande-Bretagne et Irlande */
           DST_RUM      /* Roumanie */
           DST_TUR      /* Turquie */
           DST_AUSTALT  /* Style australien avec changement en 1986 */

       Il est évident que la période de l’heure d’été en cours ne  peut  pas  être  uniquement  fournie  par  un
       algorithme  par  pays.  Ce décalage dépend de décisions politiques imprévisibles. Aussi, cette méthode de
       représentation des fuseaux horaires a été abandonnée.

VOIR AUSSI

       date(1),  adjtimex(2),  clock_gettime(2),  time(2),  ctime(3),  ftime(3),  timeradd(3),  capabilities(7),
       time(7), vdso(7), hwclock(8)

COLOPHON

       Cette page fait partie de la publication 5.10 du projet man-pages Linux. Une description du projet et des
       instructions  pour  signaler  des  anomalies et la dernière version de cette page peuvent être trouvées à
       l'adresse https://www.kernel.org/doc/man-pages/.

TRADUCTION

       La  traduction  française   de   cette   page   de   manuel   a   été   créée   par   Christophe   Blaess
       <https://www.blaess.fr/christophe/>,   Stéphan   Rafin   <stephan.rafin@laposte.net>,   Thierry   Vignaud
       <tvignaud@mandriva.com>, François Micaux, Alain Portal  <aportal@univ-montp2.fr>,  Jean-Philippe  Guérard
       <fevrier@tigreraye.org>,   Jean-Luc   Coulon   (f5ibh)   <jean-luc.coulon@wanadoo.fr>,   Julien   Cristau
       <jcristau@debian.org>,     Thomas     Huriaux      <thomas.huriaux@gmail.com>,      Nicolas      François
       <nicolas.francois@centraliens.net>,     Florentin     Duneau    <fduneau@gmail.com>,    Simon    Paillard
       <simon.paillard@resel.enst-bretagne.fr>,    Denis    Barbier    <barbier@debian.org>,    David     Prévot
       <david@tilapin.org> et Jean-Philippe MENGUAL <jpmengual@debian.org>

       Cette  traduction  est  une  documentation libre ; veuillez vous reporter à la GNU General Public License
       version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.

       Si vous découvrez un bogue dans la traduction de cette page de manuel,  veuillez  envoyer  un  message  à
       debian-l10n-french@lists.debian.org.

Linux                                              6 mars 2019                                   GETTIMEOFDAY(2)