Bug de l'an 2038![]() Le bug de l'an 2038, ou bogue de l'an 2038 (au Québec), aussi appelé Y2038 ou Epochalypse en anglais, est un bug informatique similaire au bug de l'an 2000, et dont les principales conséquences sont attendues le à 3 h 14 min 8 s, temps universel[1]. Les systèmes affectés par le bug considéreront alors être le à 20 h 45 min 52 s. Ce bug concerne potentiellement tous les systèmes d'exploitation et les programmes qui mesurent le temps avec un nombre entier codé sur 32 bits. Il concerne les formats de fichier (tels que ZIP), les systèmes de fichiers (comme le système de fichier FAT32 utilisé sur la plupart des clés USB et cartes flash) et les systèmes d'exploitation à tous les niveaux (du noyau de système d'exploitation aux langages de programmation), voire l'horloge temps réel elle-même. PrésentationLe problème concerne des logiciels qui utilisent la représentation POSIX du temps, dans laquelle le temps est représenté comme un nombre de secondes écoulées depuis le à minuit (0 heure) temps universel. Sur les ordinateurs fonctionnant en 32 bits, la plupart des systèmes d'exploitation concernés représentent ce nombre comme un nombre entier signé de 32 bits, ce qui limite le nombre de secondes à 231 − 1, soit 2 147 483 647 secondes (01111111 11111111 11111111 11111111 en binaire)[2],[3]. Ce nombre maximum sera atteint le à 3 h 14 min 7 s (temps universel). La seconde suivante, écrite 10000000 00000000 00000000 00000000 en binaire, représente −2 147 483 648 en complément à deux, soit plus de 2 milliards de secondes avant 1970, le à 20 h 45 min 52 s pour être précis[4]. Dans le domaine applicatif, le problème s'est révélé dès les années 2010 comme celui de l'an 2000 s'était révélé dès les années 1980 sur les échéanciers des plans à long terme (les tableurs utilisent depuis des dates soit glissantes, soit en format long)[réf. nécessaire]. Les logiciels concernés sont très nombreux, car la norme POSIX, inspirée des systèmes Unix, a été utilisée pour de nombreux programmes écrits en langage C pour de nombreux systèmes d'exploitation. Sur ceux de type Unix représentant le temps par un entier de 32 bits non signé (conforme à la norme POSIX), la date limite est située en 2106 et non en 2038. Ces systèmes d'exploitation sont toutefois minoritaires. Il n'existe pas de correctif simple et unique pour ce problème, car les horodatages sur 32 bits sont aussi présents dans plusieurs formats de fichiers actuels (par exemple le format ZIP). Un changement de représentation dans les ordinateurs rendrait inopérants les programmes exploitant l'actuelle équivalence entre la représentation interne et le format de fichiers. Beaucoup de travail sera donc nécessaire « en coulisses » pour que rien ou presque n'apparaisse en surface, ce qui avait déjà été le cas à l'approche de l'an 2000. Le passage à un horodatage sur 64 bits repousse la date butoir se situant au dimanche 292 277 026 596 ap. J.-C. à 15 h 30 min 8 s, soit environ 21 fois l'âge de l'Univers. Systèmes concernésStructures de donnéesDe nombreuses structures de données qui sont en usage aujourd'hui ont des représentations de temps en format 32 bits, notamment, pour les plus connues :
Exemples de systèmes qui utilisent les formats de temps sur 32 bits :
Système d'exploitationLinuxLes systèmes d’exploitation utilisant le noyau Linux en 64 bits sont tous immunisés. La version 3.17 du noyau Linux utilise une représentation interne des dates sur 64 bits[5],[6],[7], ce qui prépare les autres adaptations nécessaires, au niveau des bibliothèques standard C puis des applications. OpenBSDOpenBSD est immunisé depuis sa version 5.5 de mai 2014[8]. AndroidLa version Marshmallow 6.0 d'Android à base de noyau Linux 3.10 n’incorpore aucune correction. WindowsEn Visual C 7.1, le développeur doit explicitement utiliser le temps en 64 bits[9]. En Visual C 8, le temps est codé sur 64 bits par défaut[9]. iOSLes appareils de la marque Apple fonctionnant sous iOS fonctionnent en 64 bits.[réf. nécessaire] Systèmes de fichierExt2/3/4Les dates sont maintenant considérées comme non signées, permettant d'allonger de 68 ans leur durée de vie. Systèmes de fichier immunisésLes systèmes suivants codent leurs dates sur 64 bits : Protocoles réseauNTPNetwork Time Protocol (NTP) utilise une date de base au codée sur 64 bits dont 32 bits représentent les secondes. Ainsi il n'est pas sujet au bug de l'année 2038 mais au bug de l'année 2036. NTPv4 utilise des champs « numéro d'ère » et « début d'ère » qui permettront d'outrepasser le bug. Les versions suivantes du protocole utiliseront des dates codées sur 128 bits dont 64 bits représenteront les secondes. Format de fichier
Solutions possiblesIl n’existe pas de solution universelle pour les problèmes qui se manifesteront en raison du bug de l'an 2038. N'importe quelle altération de la définition du type de variable utilisé pour dénoter le temps La solution la plus simple proposée est de changer de système, en passant de 32 bits à 64 bits[4]. En effet, actuellement, la plupart des systèmes informatiques qui ont été conçus pour utiliser du matériel à 64 bits fonctionnent déjà avec des variables Voir aussiArticles connexes
Notes et références
AnnexesLiens externes
|
Portal di Ensiklopedia Dunia