Le dépassement d'entier sur SDL_GetTicks
à l'attention des sages

La fonction SDL_GetTicks retourne un entier non signé sur 32 bits chargé de représenter le nombre de millisecondes écoulées depuis l'initialisation de la librairie SDL2. En apparence anodin, un dépassement d'entier (ou integer overflow) sur la valeur de retour de cette fonction est toutefois intéressant à relever.

Compréhension du problème

Une application SDL2 doit être exécutée de manière continue pendant 49 jours (soit 232 millisecondes) pour entrainer un dépassement d'entier sur Uint32 SDL_GetTicks(void) et provoquer la troncature du résultat. Ce cas spécifique peut prêter à sourire mais privilégier les bonnes pratiques permet de se préparer efficacement en vue de situations plus critiques.

La solution élégante proposée par Raymond Chen dans son blog se transpose facilement à un contexte SDL2. En considérant StartTime comme l'entier non signé destiné à loger le temps de départ et IntervalTime comme la durée d'attente entre chaque frame, on obtient l'expression sécuritaire SDL_GetTicks() - StartTime >= IntervalTime. Cette solution fonctionne étant donné la nature particulière des entiers non signés.

Complément d’information

L'exemple illustré sur la page Wiki officielle de la fonction SDL_GetTicks souffre d'un problème d'overflow susceptible de valider prématurément la condition currentTime > lastTime + 1000. Dans l'exemple, la valeur exprimée par currentTime a de grandes chances de se trouver supérieure au résultat de l'expression lastTime + 1000 quand celui-ci s'inscrit au-delà des capacités de l'espace de stockage disponible.

À des fins d'archivage, Le code complet (extrait du Wiki de la librairie SDL2) est mis à disposition ci-dessous :

unsigned int lastTime = 0, currentTime;
while (!quit) {
 // do stuff
 // ...

 // Print a report once per second
 currentTime = SDL_GetTicks();
 if (currentTime > lastTime + 1000) {
  printf("Report: %d\n", variable);
  lastTime = currentTime;
 }
}

Internet Explorer, aujourd'hui oublié
mais empreint d'histoire

Les technologies web sont imaginées et conçues dans un cadre indépendant, loin des aspirations lucratives de sociétés influentes. En s'illustrant à promouvoir la compatibilité de ces technologies, le World Wide Web Consortium dessine les contours d'un environnement technologique sain.

Le W3C est une entité, à vocation altruiste, chargée de réaliser le processus de normalisation des technologies web. L'organisme propose des standards industriels à l'attention des éditeurs tout en s'efforçant de concilier les intérêts de la communauté mondiale.

Aujourd'hui incontestés, ces standards n'ont pourtant pas toujours été au centre des attentions. En 1995, Microsoft Internet Explorer voit le jour et connait une adoption rapide auprès du public en s'appuyant notamment sur la base des utilisateurs Windows afin de prospérer.

Le web en orbite autour d'un seul acteur

Aussitôt en situation de monopole, Microsoft fait principalement le choix d'intégrer dans son navigateur des fonctionnalités propriétaires absentes des recommandations du W3C. Une décision intervenue au détriment de la prise en charge naturelle et spontanée des standards web normalisés. Ainsi, le navigateur abritera-t-il des technologies (certainement intéressantes mais malheureusement) spécifiques à Microsoft telles que Vector Markup Language ou encore Silverlight.

Au début des années 2000, Microsoft Internet Explorer joue un rôle actif dans les principes qui président à la conception de la plupart des sites Internet. Avec de nombreuses applications métiers en partie basées sur d'anciennes versions du navigateur, Internet Explorer verra même jusqu'à sa longévité échapper au contrôle de l'éditeur.

Un passage de l'histoire qui laisse deviner comment la compatibilité généralisée des technologies web a parfois relevé de la fantaisie. Aujourd'hui, il peut être intéressant de se rappeler que les recommandations du W3C survivent mieux à l'épreuve du temps faisant oublier les choix d'implémentation autrefois portés par Microsoft. Des standards web qui, bien loin de leur mise en œuvre dans les navigateurs, pourraient être l'élément de référence le plus décisif pendant la création d'une application.