Entrée en matière
Cette démonstration, créée pour la Fête de la Science 2015, a été imaginée sous forme de clin d’oeil.
En effet, quoi de plus banal que de faire bouger le bras Youpi en le contrôlant via une application sur PC ? Aucun intérêt, en tout cas en terme de nouveauté.
Mais par contre, si au lieu d’une bête interface graphique bling-bling et de mauvais goût sous Ouindose 14 on fournit aux utilisateurs un bon vieux truc rétro 100% texte avec un Minitel rescapé de la déchetterie, là le public fait "waou". Ou plutôt, les parents font "tiens, un Minitel" et les enfants "c’est quoi ça" :)
En tout cas, nous avons eu le plaisir de constater un intérêt et un amusement massifs des petits et grands lors de cette Fête de la Science
Les ingrédients
Vous l’aurez déjà compris, nous avons :
- un bras Youpi tout droit venu des 80ies, en à peu près parfait état de marche [1]
- un Minitel de la même époque, en parfait état de marche aussi
Le but est de permettre aux utilisateurs de donner des commandes au bras via le clavier du Minitel, afin de lui faire exécuter divers mouvements.
Entre les deux il va falloir ajouter un peu de quincaillerie d’aujourd’hui, de manière à :
- s’interfacer avec les signaux de contrôle disponibles sur la prise DB25 du bras Youpi, initialement destinée à la connexion vers les TO7 et autres antiquités datant du plan "Informatique pour Tous"
- recréer un serveur Videotext (aka Télétexte) permettant au Minitel de retrouver son environnement d’alors,
- faire discuter le serveur Videotext et l’interface de contrôle du bras
L’approche
Nous étions deux, Damien et moi, à nous être embarqués dans cette aventure, et il convenait donc de pouvoir se distribuer le boulot afin de travailler en parallèle, mais de manière la plus indépendante possible.
Le chantier s’est donc décomposé en deux sous-projets :
- la réalisation par Damien de l’interface de contrôle du bras avec une Arduino bien connue de nos services, dialoguant avec l’extérieur via sa liaison série/USB
- la réalisation par votre serviteur du serveur Videotext, tournant une RaspberryPi, tout aussi bien connue de nos services
L’architecture globale du système se présente comme ci-dessous :
La liaison Arduino-Youpi fait appel aux GPIO de l’Arduino, qui a pour rôle de générer les signaux de mouvement des moteurs tels qu’attendus sur la prise DB25 d’origine, et de récupérer l’état des capteurs de position de référence sur cette même prise. La documentation d’origine, très détaillée, a été d’un grand secours à ce niveau.
L’Arduino dialogue avec la Raspberry via une liaison USB série, en utilisant un protocole reproduisant celui utilisé par les servomoteurs numériques AX12, déjà présenté dans nos articles. Pourquoi ce choix ? Pour permettre de tester en parallèle la partie interface utilisateur avec un bras construit avec des AX12. C’est ce protocole AX12 qui a fait office de point de liaison entre les deux sous-projets.
Le Minitel n’utilise pas sa liaison téléphonique bien entendu, mais la liaison télé-informatique disponible via une embase DIN [2] sur le modèle récupéré, qui véhicule les même échanges mais sur une interface série TTL. Un simple câble convertisseur FTDI-série TTL 5V équipé d’une prise DIN permet d’assurer la liaison Raspberry-Minitel. Le protocole qui circule sur cette liaison est le Videotext propre au Minitel.
La Raspberry a donc pour fonction de se présenter au Minitel comme un serveur Videotext, lui envoyant les pages à afficher et récupérant les saisies clavier.
Ces saisies sont traduites en actions de navigation au sein des pages du serveur, et en ordres AX12 à destination du bras Youpi, via l’Arduino.
Le comment
Côté Arduino, tout est programmé avec l’IDE habituel. Le code embarqué décode les messages au format AX12 qu’il reçoit en provenance de la Raspberry, et simule les registres de contrôle des AX12 (position cible, vitesse de mouvement, accélérations, position courante,...). Il génère les signaux spécifiques à destination du bras, l’avance des pas des moteurs étant obtenue par une succession de changements d’état ses signaux correspondant, selon une logique assez complexe. Chapeau à Damien d’avoir réussi à se dépêtrer de tout cela. Le code source est disponible sous GitHub.
Sur la Raspberry nous avons un serveur Videotext, qui implémente le protocole en conformité avec la spécification officielle. Malgré l’apparente complexité de la tâche, elle a pu être menée à bien grâce à la documentation très détaillée des matériels de l’époque, qui bien que d’apparence plus "rustique" que les documents actuels, peut en remontrer en qualité à bon nombre de soit-disant documentations diffusées de nos jours.
Cela a permis de créer une petite lib au-dessus du protocole Videotext pour gérer plus facilement l’affichage de pages, la gestion de formulaires, la gestion des saisies, l’affichage d’images,... Elle est disponible sur GitHub.
Le serveur est implémenté à la mano sans environnement particulier. J’ai oublié de préciser un détail : toute la partie Raspberry est implémenté en Python. On ne change pas une équipe qui gagne ;). Son code source est disponible sous GitHub.
Le mot de la fin
Voilà comment faire du neuf avec du vieux.
Et aussi comment donner une occasion d’expliquer aux jeunes générations que :
- non, Internet n’a pas toujours existé
- on pouvait quand même communiquer avant
- la France a été un précurseur de premier ordre, dans la mesure où il n’est pas exagéré de dire que le Minitel et le réseau Télétexte ne sont rien de moins que l’ancêtre de l’Internet moderne. Quand on réalise de plus que le Minitel ne pouvait jamais se planter ni chopper de virus [3], on mesure le bonheur dans lequel on vivait en ces temps révolus :)
- Free n’existerait peut-être pas si un certain Xavier Niel (son fondateur) n’avait pas fait fortune à cette époque en développant les premiers serveurs coquins sur Minitel. Comme quoi, le sexe peut aussi faire avancer la science :)
Quelques références utiles
- http://youpi.forler.ch/
- http://millevaches.hydraule.org/info/minitel/specs/
- http://cyrille.giquello.fr/electronique/minitel
Des scans de documentations sont également annexés à cet article.