fxSDK, un SDK alternatif pour écrire des add-ins
Posté le 29/08/2014 22:00
Cette page sert d'index pour la série de topics du fxSDK.
Le fxSDK est une collection d'outils permettant de développer des add-ins pour les calculatrices Casio des séries Graph. C'est une alternative au
fx-9860G SDK et
PrizmSDK qui ne sont plus activement maintenus, et le compagnon classique de mon noyau
gint.
Index des topics
Ce projet existe depuis 2015, alors il y a pas mal de topics liés. En voici une liste complète !
Topics principaux
Installation du fxSDK
Tutoriels
Compatibilité sur calculatrice et PC
Côté PC, le fxSDK est compatible avec
Linux, Mac OS, et WSL pour Windows ; normalement tout le monde peut l'utiliser. Je teste constamment sous Linux, et WSL est un Linux donc c'est testé aussi. Je n'ai pas de Mac OS donc il peut y avoir quelques surprises, mais en général c'est l'affaire de corriger un bug ou deux.
En termes de calculatrices, le fxSDK supporte :
Calculatrices monochromes
- Graph 35+E II
- Graph 35+ USB / Graph 35+E (SH3/SH4)
- Graph 75/75+/75+E
- Graph 85/85 SD/95 (SD) (pas activement testé)
Calculatrices couleurs
- Graph 90+E / fx-CG 50
- Prizm fx-CG 10/20
Comment installer le fxSDK et coder des add-ins
Le fxSDK s'installe à partir de dépôts Git sur la
forge de Planète Casio (par exemple
Lephenixnoir/fxsdk). Il y en a un peu beaucoup, donc manuellement c'est assez long. Pour que ça aille plus vite et pour simplifier le travail des débutants, il y a un outil appelé
GiteaPC qui peut faire ça pour vous.
Si vous utilisez Windows, vous aurez besoin de WSL pour accéder à un système Linux dans Windows. Heureusement, Microsoft a fait ça bien et c'est facile à faire. Voyez le
tutoriel d'installation de WSL 2 (et l'explication rapide de
ce que WSL 2 est).
Si vous utilisez Mac OS, ouvrez l’œil en lisant les topics pour ne pas manquer les informations supplémentaires et éventuelles déviations par rapport à la procédure normale sous Linux.
Méthode automatique avec GiteaPC (plus rapide / recommandée pour les débutants)
- Suivez le tutoriel d'utilisation de GiteaPC, qui explique comment obtenir le fxSDK.
Méthode automatique avec plugin VS Code
- Yannis300307 a créé un plugin VS Code Casio Dev Tools qui fonctionne sous Windows (avec WSL) et Debian (probablement les dérivés aussi).
Méthode AUR pour les utilisateurs Arch/Manjaro/dérivés (ils se reconnaîtront)
- Dark Storm maintient MiddleArch, un dépôt de paquets précompilés qui a entre autres le fxSDK.
Méthode manuelle (plus fine / classique pour les habitués)
- Compilez et installez le cross-compilateur GCC pour SuperH.
- installez (dans cet ordre) les dépôts fxSDK, OpenLibm, fxlibc, gint ; en option, Slyvtt/µSTL_2.3.
Description sommaire du fxSDK
Pour une introduction à l'utilisation du fxSDK qui montre comment utiliser les outils pour développer un add-in, lisez plutôt les
tutoriels d'utilisation de gint. Cette section est juste une description sommaire.
Le cœur du fxSDK est un cross-compilateur GCC pour SuperH, habituellement nommé
sh-elf-gcc. Bien sûr on a avec toute la suite d'outils, dont
as,
ld,
objdump,
objcopy (entre autres). Contrairement au vieux compilateur du SDK, GCC est un compilateur moderne avec beaucoup d'options et capable de très solides optimisations.
Sur la calculatrice, c'est
le noyau gint qui fait la majorité du travail. Il remplace fxlib/libfxcg et une partie de l'OS pour vous offrir des fonctionnalités plus cool et plus rapides. Les add-ins développés avec le fxSDK utilisent gint toutes les trois lignes !
Il y a enfin plusieurs outils utiles sur le PC qui sont utilisés durant le développement ou l'utilisation des add-ins :
- fxsdk est un script shell qui permet de créer et compiler les projets sans se prendre trop la tête. Le système de compilation officiel pour les add-ins est CMake, mais un système plus ancien de Makefile est encore supporté.
- fxconv est un outil très polyvalent qui convertit à la compilation les assets (images, polices, maps....). Il permet de travailler avec des logiciels et formats de fichiers normaux sur le PC et d'avoir automatiquement un format optimisé sur la calculatrice. fxconv est extrêmement extensible et chaque projet peut ajouter des conversions personnalisées.
- fxgxa crée les fichiers g1a (format des add-ins pour Graph monochromes) et g3a (format des add-ins pour Graph couleurs) à partir des programmes compilés.
- fxlink est un outil de communication qui peut transférer des fichiers vers les Graph 35+E II et Graph 90+E en ligne de commande, mais aussi échanger interactivement avec les add-ins gint par le câble USB, et est couramment utilisé pour réaliser des captures d'écran ou captures vidéo des add-ins.
Changelog et informations techniques
Ci-dessous se trouve la liste des posts annonçant les nouvelles versions du fxSDK, ainsi que des liens vers les instructions/tutoriels supplémentaires publiés avec.
Citer : Posté le 20/11/2021 09:49 | #
Wait c'est vraiment louche. Le bon dossier est explicitement ajouté au chemin d'include dans le CMakeLists.txt. Et surtout le fait que CMAKE_TOOLCHAIN_FILE soit inutilisé est louche.
Je soupçonne qu'il te reste des fichiers d'une tentative de build précédente. Essaie :
% giteapc uninstall Vhex-Kernel-Core/fxlibc
# On réessaie
% giteapc install Vhex-Kernel-Core/fxlibc
% giteapc install Lephenixnoir/gint
Citer : Posté le 20/11/2021 10:28 | #
https://www.toptal.com/developers/hastebin/otehitizev.rb
bizzare, la premiere fois quand j'ai installe fxlibc openlibm me manquait, mais en l'installant avec giteapc install OpenLibm ca marchait, mais ce n'est pas le cas de gint
Citer : Posté le 20/11/2021 10:36 | #
Non c'est le même problème, c'est toujours fxlibc qui ne marche pas (tu peux le voir à la dernière ligne de giteapc qui dit "<giteapc> Vhex-Kernel-Core/fxlibc: Building").
Je ne comprends pas comment l'en-tête peut manquer. Qu'est-ce que te donne la commande suivante ?
Désolé y'a des trucs comme ça, ça marche pour tout le monde sauf dans un cas particulier, et tu es ce cas particulier... :x
Citer : Posté le 20/11/2021 10:40 | #
Citer : Posté le 20/11/2021 11:04 | #
Ok donc l'installation de OpenLibm il est là le problème. Et en fait je sais pourquoi, regarde où il a installé :
cp -RpP -f libopenlibm.a /home/onee/opt/sh-elf-2.32-9.2.0/
mkdir -p /home/onee/opt/sh-elf-2.32-9.2.0/include/openlibm
cp -RpP -f include/*.h /home/onee/opt/sh-elf-2.32-9.2.0/include/openlibm
cp -RpP -f src/*.h /home/onee/opt/sh-elf-2.32-9.2.0/include/openlibm
Et pourtant regarde les versions de binutils/gcc que giteapc pensait utiliser :
(...)
<sh-elf-gcc> Version 11.1.0 already installed, skipping rebuild
Selon toute probabilité tu as deux compilateurs avec le même nom et ça rend les scripts d'installation confus.
Citer : Posté le 20/11/2021 11:10 | #
Je ne m'y connais pas trop, comment est-ce que je peux desinstaller une des deux versions?
gcc --version indique que c'est la version 9.3.0, et pour l'installation j'ai pris le fichier .tar.xz 11.2.0 et binutils 2.37
Citer : Posté le 20/11/2021 11:34 | #
Alors c'est pas gcc mais sh-elf-gcc ; gcc tout seul c'est celui qui compile des programmes pour ton PC, sh-elf-gcc c'est celui qui compile des programmes pour la calculatrice.
Il faut d'abord cerner exactement ce que tu as sur ton système.
Essaie "which -a sh-elf-gcc" pour voir si tu en as plusieurs dans le PATH ; essaie aussi "sh-elf-gcc --print-file-name=." pour voir quel chemin exact est utilisé. Ton /home/onee/opt/sh-elf-2.32-9.2.0 est sans doute issu du tutoriel GCC. Est-ce que tu as recompilé GCC avec GiteaPC ou est-ce que tu as mis :any dans l'installation ?
Citer : Posté le 20/11/2021 11:43 | #
Est-ce que tu as recompilé GCC avec GiteaPC ou est-ce que tu as mis :any dans l'installation ?
je crois bien que je l'ai recompile avec GiteaPC
Citer : Posté le 20/11/2021 11:47 | #
Ah c'est marrant, tu as bien deux compilateurs mais un seul est dans le PATH. Du coup le but ce serait de supprimer l'ancien qui n'est pas très intéressant (et plus vieux) :
Tu peux aussi juste déplacer le dossier pour l'instant et le supprimer plus tard quand tout marchera, pour éviter toute mauvaise surprise (on ne sait jamais).
Une fois que c'est fait, "which sh-elf-gcc" devrait t'afficher celui de GiteaPC et dans ce cas tu peux supprimer/recompiler fxlibc comme dans ce message, et cette fois il devrait s'installer dans le bon (le seul qui reste !).
Citer : Posté le 20/11/2021 11:56 | #
sh: 0: getcwd() failed: No such file or directory
Desole pour tout le derangement le dieu planet-casio veut que je me repentisse de mes peches
Citer : Posté le 20/11/2021 11:57 | #
Le problème avec la commande que tu viens d'exécuter c'est que tu es dans un dossier qui n'existe plus. Fais cd pour revenir dans ton dossier personnel et ça ira un peu mieux déjà.
Citer : Posté le 20/11/2021 13:24 | #
Comment est-ce que ca marche sous WSL?
Citer : Posté le 20/11/2021 13:42 | #
Pareil que sous Linux - la commande "cd" qui te permet de changer de dossier te ramène à la racine de ton dossier perso quand tu n'indiques pas d'arguments. Celui-là on sait qu'il existe et du coup cette histoire de getcwd() ne te gênera pas.
Citer : Posté le 20/11/2021 14:05 | #
je crois savoir d'ou vient l'erreur, mais je suis encore en train de tester
quand je preparais l'environment (environnement?) de compilation, je copiais cette commande
mais j'utilisais les versions 2.37 et 11.2.0, et non 2.32 et 9.20
pensez a ce que vous copiez les enfants!
Citer : Posté le 20/11/2021 14:08 | #
Quand tu installes avec GiteaPC cette commande est ignorée, GiteaPC donne son propre PREFIX qui est dans le style .local/share/giteapc/etc.
Citer : Posté le 20/11/2021 15:37 | #
Apres reinstallation de linux mint, je rencontre ce probleme a l'etape de la compilation de binutils
Citer : Posté le 20/11/2021 15:39 | #
Si tu as tout réinstallé du début ça ne vaut pas la peine de refaire le tutoriel - utilise plutôt le sh-elf-gcc de GiteaPC (qui automatise le tutoriel), sauf si tu tiens à le faire à la main.
Il est probable qu'il te manque des outils de développement actuellement, les installations neuves n'ont pas toujours tout. Tu peux regarder dans config.log, comme indiqué par la dernière ligne d'erreur, pour voir exactement ce qu'il a tenté de faire avec le compilateur et qui n'a pas marché.
Citer : Posté le 20/11/2021 17:22 | #
ENFIN
Merci infiniment a toi, Lephenixnoir
Citer : Posté le 20/11/2021 17:23 | #
Bon ça va alors ! Désolé que ça t'ait pris aussi longtemps, c'est tellement dur à rendre consistant...
Citer : Posté le 20/11/2021 18:01 | #
Bon ça va alors ! Désolé que ça t'ait pris aussi longtemps, c'est tellement dur à rendre consistant...
C'est parfois un peu laborieux mais en même temps c'est une mise en bouche de souvent ce que l'on sera amené à croiser lors du développement d'applis. C'est donc formateur ce genre d'infortune
Citer : Posté le 20/11/2021 18:03 | #
Je ne vais pas mentir, des fois c'est aussi un filtre... c'est juste pas possible de développer en C avec un pied dans le bas-niveau si on n'arrive pas à maîtriser un peu le terminal, voir où sont les erreurs dans la sortie d'un programme, et d'autres trucs basiques du genre. Sauf qu'on peut pas dire ça quand les amateurs un poil trop optimistes posent des questions sans queue ni tête, parce que ça fait passer pour un con. :x