[Tutoriel] Installation manuelle de GCC (et du fxSDK)
Posté le 31/05/2014 17:02
Parmi les compilateurs C/C++ modernes de premier plan (LLVM, GCC, MSVC...), GCC est le seul à avoir un backend SuperH, ie. capable de générer des add-ins pour les calculatrices CASIO. Dans ce tutoriel, on va voir comment compiler GCC à la main. J'y mentionne également par le symbole
les étapes supplémentaires nécessaires pour installer le fxSDK tout entier à la main.
Ce tutoriel était initialement utilisé pour toutes les installation de GCC pour la calculatrice, mais il y a maintenant des méthodes automatiques via le dépôt
sh-elf-gcc, via
MiddleArch ou même l'installation complète du fxSDK avec
GiteaPC. Le texte ci-dessous est donc destiné à des personnes relativement expérimentées avec le terminal et les processus classiques de compilation, et spécifiquement à ceux qui voudraient tester des configurations inhabituelles.
Pour relire l'ancien tutoriel, voir sur la forge Gitea.
Ce tutoriel est écrit pour Linux mais vous pouvez le suivre sous Windows 10 en utilisant
WSL qui vous donnera accès à Ubuntu.
1. Présentation du processus
Dans ce tutoriel, on va compiler plusieurs logiciels. Côté compilateur, d'abord
binutils, une suite de programmes qui gère l'assembleur, les fichiers objets, les bibliothèques, et l'édition des liens ; puis
GCC, le compilateur C/C++ en lui-même.
Ensuite on va faire un détour par le fxSDK pour installer la bibliothèque mathématique et la bibliothèque standard C qui sont nécessaires pour avoir accès à la totalité du langage C.
On reviendra alors vers GCC, puisqu'une fois la lib standard C installée on peut compiler la bibliothèque standard C++, qui est là aussi nécessaire pour avoir accès à la totalité du langage C++.
Enfin on pourra finir l'installation du fxSDK avec gint et d'autres bibliothèques.
[fxSDK] Commencez par installer le dépôt
fxsdk, qui fournit la sysroot dans laquelle on va installer le compilateur. C'est un
cmake/
make classique.
2. Installation des dépendances
Nos calculatrices utilisent des processeurs de la famille SuperH, on ne peut donc pas utiliser le même compilateur C que quand on programme pour l'ordinateur. On va utiliser un
cross-compilateur qui ne s'appelera pas
gcc mais
sh-elf-gcc, attention à ne pas confondre !
Téléchargez la dernière version de binutils (
téléchargement ici) ainsi que la dernière version de GCC (
téléchargement ici). En cas d'erreur insondable, vous pourrez toujours tenter d'autres versions plus tard.
Attention : Si votre GCC système est en version 12.1 ou 12.2 (tapez
gcc -v pour le déterminer), vous devez prendre GCC 11.1 pour la calculatrice à cause de
ce bug de GCC pour x86_64.
Bien sûr GCC est un logiciel complexe avec pas mal de dépendances. Voici de quoi les installer :
# Pour Debian, Ubuntu, Mint, WSL pour Windows, et autres dérivés de Debian :
% sudo apt install libmpfr-dev libmpc-dev libgmp-dev libpng-dev libppl-dev flex g++ git texinfo
# Pour Arch Linux, Manjaro, et autres dérivés de Arch :
% sudo pacman -S mpfr libmpc gmp libpng ppl flex gcc git texinfo
- MPFR : calcul flottant à précision arbitraire
- MPC : calcul complexe à précision arbitraire
- GMP : arithmétique entière multi-précision
- libPNG : manipulations d'images PNG
- PPL : optimisation polyhédrique (optimisation magique)
- flex : générateur d'analyseurs lexicaux
- g++ : compilateur C++ pour votre système
- git : gestionnaire de versions
- texinfo : générateur de documentation formatée
3. Préparation de l'environnement de compilation
Le compilateur et toutes les bibliothèques pour la calculatrice vont être installées dans un même dossier. Si vous utilisez le fxSDK, ce dossier est pré-choisi et la commande
fxsdk path sysroot vous l'affiche. Sinon vous pouvez aller où vous voulez, mais restez dans votre dossier personnel.
% export PREFIX="$(fxsdk path sysroot)"
# Exemple de dossier hors fxSDK :
# export PREFIX="$HOME/opt/sh-elf-2.39-11.1.0"
% mkdir -p $PREFIX
Assurez-vous que
$PREFIX/bin est dans votre PATH. Extrayez le contenu des archives que vous avez téléchargées dans un dossier temporaire, et créez deux répertoires
build-binutils et
build-gcc.
% tar -xJf binutils-2.39.tar.xz
% tar -xJf gcc-11.1.0.tar.xz
% mkdir build-binutils build-gcc
On va ensuite appliquer quelques patchs. On va d'abord toucher un fichier de binutils pour éviter la régénération d'un parser avec bison qui ne marche plus depuis longtemps :
% touch binutils-2.39/intl/plural.c
Si vous utilisez GCC 11.1 (et sans doute quelques versions d'avant), téléchargez de plus
ce patch qui désactive des tests de configuration inutilement aggressifs dans la lib C++ et appliquez-le :
% patch -u -N -p0 < gcc-11.1.0-libstdc++-v3-skip-dlopen.patch
4. Compilation de binutils
La compilation de binutils est un configure/make classique. Les options qu'on utilise sont :
- --prefix pour indiquer le dossier d'installation final.
- --target="sh3eb-elf" pour spécifier qu'on veut un cross-compilateur pour SuperH.
- --with-multilib-list="m3,m4-nofpu" indique plus précisément qu'on veut une variante pour SH3 et une pour SH4 sans FPU.
- --program-prefix="sh-elf-" renomme le compilateur de sh3eb-elf-gcc à sh-elf-gcc vu qu'on a aussi le SH3.
Il n'y a pas beaucoup d'autres options intéressantes, mais vous pouvez les voir toutes avec
configure --help.
% cd build-binutils
% ../binutils-2.39/configure --prefix="$PREFIX" --target="sh3eb-elf" --with-multilib-list="m3,m4-nofpu" --program-prefix="sh-elf-"
Une fois que tout est configuré, il n'y a plus qu'à compiler et à installer. Normalement ça va assez vite, comptez quelques minutes.
% make -j4
% make install-strip
Les exécutables de
binutils ont dû apparaître dans
$PREFIX/bin Essayez
sh-elf-ld --version qui doit vous renvoyer la version de binutils (ici 2.39).
5. Compilation de gcc et de libgcc
Ensuite c'est pareil mais pour GCC. En plus des options précédentes, on indique :
- --enable-languages="c,c++" qui spécifie les compilateurs qu'on veut. Si vous voulez expérimenter avec d'autres langages notamment Ada, D, Go ou Fortran, c'est là qu'il faut commencer !
- --without-headers qui indique essentiellement qu'on veut un cross-compilateur.
- --enable-clocale="generic" qui simplifie le module <locale> de la lib C++.
- --enable-libstdcxx-allocator qui fait de même avec les allocateurs mémoire.
- --disable-threads qui désactive le threading (qu'on n'a pas).
- --disable-libstdcxx-verbose qui élimine des logs dans la lib C++.
- --enable-cxx-flags="-fno-exceptions" qui désactive les exceptions durant la compilation de la lib C++.
Voyez
le guide de configuration pour toutes les options utiles.
% cd "$PREFIX/build-gcc"
% ../gcc-11.1.0/configure --prefix="$PREFIX" --target="sh3eb-elf" --with-multilib-list="m3,m4-nofpu" --enable-languages="c,c++" --without-headers --program-prefix="sh-elf-" --enable-clocale="generic" --enable-libstdcxx-allocator --disable-threads --disable-libstdcxx-verbose --enable-cxx-flags="-fno-exceptions
Cette fois la compilation occupera entre 10 et 30 minutes... ou 5/6 heures sur un vieux Raspberry Pi.
% make -j4 all-gcc all-target-libgcc
% make install-strip-gcc install-strip-target-libgcc
Avec ça vous devez pouvoir taper
sh-elf-gcc -v et la version et les options de compilation.
[fxSDK] C'est le moment d'installer
OpenLibm, avec
make.
[fxSDK] Installez aussi la lib C,
fxlibc, un autre
cmake/
make classique.
6. Compilation de libstdc++
On peut maintenant revenir dans le dossier de compilation de GCC et compiler des libs plus évoluées, comme la lib C++. Si vous testez d'autres langages (par exemple D) c'est le moment de compiler les libs qui vont avec (libphobos), ou même de compiler libssl, libiberty, etc. selon vos goûts.
% make -j4 all-target-libstdc++-v3
% make install-strip-target-libstdc++-v3
Et voilà, la toolchain est complète. Si vous manquez d'espace disque vous pouvez supprimez les archives, dossiers de sources, et dossiers de build de binutils et GCC.
Vous pouvez aussi installer
gdb dans la même veine que binutils pour pouvoir debugger les add-ins à distance.
[fxSDK] Installez maintenant
gint, et les autres libs qui vous plaisent (eg. libprof, zlib, etc).
Et voilà, vous avez un compilateur C/C++ complet voire un SDK complet pour programmer des add-ins.
Fichier joint
Citer : Posté le 14/10/2020 21:01 | #
Ah ben voilà qui est serait un problème clair. Au tout début de la partie 3, juste après avoir créé la variable PREFIX, la commande mkdir -p "$PREFIX" est supposée le créer comme dossier. Cela dit, il est possible que Windows l'affiche de cette façon parce qu'il est dans WSL (?). Tu peux vérifier si c'est un dossier ou pas avec la commande ls -ld "$PREFIX", qui doit t'afficher une ligne avec ses propriétés. C'est un dossier si la ligne commence par un d.
Accessoirement, si tu suis strictement le tutoriel, tout doit être dans ce dossier, y compris les archives .tar.xz, et c'est depuis ce dossier que tu lances la commande tar.
Citer : Posté le 14/10/2020 21:02 | #
ca me mets ca :
drwxr-xr-x 1 root root 4096 Oct 14 12:39 /root/opt/casio/sh-elf-2.32-9.2.0
donc c'est bien un dossier...
Ajouté le 14/10/2020 à 21:04 :
En fait, je n'obtiens pas d'erreur lorsque je mets le tar.xz dans le prefix, mais en faisant tree -L 1 , il n'apparait pas...
Citer : Posté le 14/10/2020 21:05 | #
Donc pas de problème de ce côté-là a priori. Par contre il appartient à root, donc tu risques de devoir mettre sudo un peu partout (ce n'est normalement pas grave pour le tutoriel).
Vérifie que tu as bien l'archive .tar.xz à l'intérieur du dossier sh-elf-2.32-9.2.0, avec à ce stade rien d'autre que l'archive de GCC. En gros, si tu fais
tree -L 1
Tu dois obtenir juste les deux archives. Si c'est le cas tu peux essayer de reprendre.
Citer : Posté le 15/10/2020 11:07 | #
En fait pour recapituler :
Je fais :
mkdir -p $PREFIX
cd $PREFIX
Pas d'erreur...
Puis vu que mon fichier est telechargé depuis windows :
toujours pas d'erreur...
et là je tombe sur l'erreur ...
Après peut être qu'il faut mettre PREFIX a la place de sh-elf-2.32-9.2.0 ?
Je vais tester ...
Citer : Posté le 15/10/2020 11:14 | #
tar -xf /mnt/c/Users/utilisateur/Downloads/binutils-2.28.1.tar.xz
Pas besoin d'aller copier le fichier depuis Windows vers WSL, suffit juste de l'extraire sur place. Ça évitera les problèmes
Citer : Posté le 15/10/2020 11:16 | #
(Je note d'abord que ton $HOME n'est pas censé être vide, ça doit ressembler à /home/potter360. Si possible il faut aller là plutôt que dans /opt parce que c'est un dossier système.)
(Aussi le but c'est de mettre les versions de binutils et GCC dans le nom, si tu utilises binutils 2.28 ça peut être utile de nommer ton dossier sh-elf-2.28-9.2.0 ^^")
La première partie avec le mkdir ne se plaindra pas si le dossier existe déjà et pas non plus s'il contient des choses. Autrement dit si tu n'as pas vidé ou supprimé le dossier depuis que tu as rencontré le problème avec tar je doute que ça ce soit résolu tout seul.
Je ne sais toujours pas ce que tu as dans ton dossier donc c'est difficile de comprendre !
Btw, tu n'as jamais besoin d'écrire le nom du dossier. La variable $PREFIX est là pour ça.
mkdir -p "$PREFIX"
cd "$PREFIX"
cp /mnt/c/Users/utilisateur/Downloads/binutils-2.28.1.tar.xz . # . signifie "dossier courant"
tar -xJf binutils-2.28.1.tar.xz # puisque c'est le dossier courant, pas besoin de mettre le chemin
Citer : Posté le 15/10/2020 11:21 | #
C'est bon !
En fait il fallait mettre $PREFIX au lieu de /opt/casio/sh-elf-2.32-9.2.0 !
Merci pour votre aide !
Ajouté le 15/10/2020 à 11:25 :
(Je note d'abord que ton $HOME n'est pas censé être vide, ça doit ressembler à /home/potter360. Si possible il faut aller là plutôt que dans /opt parce que c'est un dossier système.)
Ha je ne savais pas...
Maintenant que j'ai tout fait sur /opt/casio est ce que je dois changer ou je peux garder ça ?
Citer : Posté le 15/10/2020 11:30 | #
Compte tenu de ta remarque :
Il semble évident que $PREFIX n'est pas /opt/casio/sh-elf-2.32-9.2.0. C'est peut-être déjà dans ton home. Un petit coup de echo "$PREFIX" te montrera tout de suite où ça mène.
Citer : Posté le 15/10/2020 11:34 | #
Autre problème à
J'obtiens :
configure: error: no acceptable C compiler found in $PATH
See `config.log' for more details.
Citer : Posté le 15/10/2020 11:36 | #
Oh mon dieu t'es dans /root, quel massacre. Tu devrais au moins avoir un utilisateur autre que root dans ton installation WSL... envisage vraiment d'en créer un avant de continuer le tutoriel ^^"
Et il faut que tu installes le compilateur, probablement dans le paquet build-essential.
Citer : Posté le 15/10/2020 11:36 | #
Oh mon dieu t'es dans /root, quel massacre. Tu devrais au moins avoir un utilisateur autre que root dans ton installation WSL... envisage vraiment d'en créer un avant de continuer le tutoriel ^^"
Et il faut que tu installes le compilateur, probablement dans le paquet build-essential.
Mais du coup je fais comment ?
Ajouté le 15/10/2020 à 11:37 :
Concrétement ?
Ajouté le 15/10/2020 à 11:54 :
Pour installer le compilateur ?
Citer : Posté le 15/10/2020 11:54 | #
Pour installer GCC pour ton PC (celui qui te permettra de compiler GCC pour la calculatrice), sudo apt install build-essential.
Citer : Posté le 15/10/2020 12:08 | #
Merci !
configure: error: Building GCC requires GMP 4.2+, MPFR 2.4.0+ and MPC 0.8.0+.
ce problème ?
Ajouté le 15/10/2020 à 12:22 :
Désolé je suis chiant...
Citer : Posté le 15/10/2020 12:23 | #
sudo apt-get install libmpfr-dev
sudo apt-get install libmpc-dev
sudo apt-get install libgmp-dev
Citer : Posté le 15/10/2020 12:24 | #
Merci !
Citer : Posté le 15/10/2020 12:33 | #
Sinon (et pour les futurs arrivants aussi), les binaires déjà compilés : https://puu.sh/GDfOw.zip
Ecrivez vos programmes basic sur PC avec BIDE
Citer : Posté le 22/10/2020 11:40 | #
eeeeee le dépot est indisponible (404)
Citer : Posté le 22/10/2020 11:42 | #
Corrigé. Mais je rappelle quand même que la libc de memallox est expérimentale.
Citer : Posté le 22/10/2020 13:10 | #
-_- j'ai installé pour sh3 alors que j'ai une graph 35+E II (sh4)
on peux chancher sans reconpiler?
../gcc-9.2.0/configure --prefix=$PREFIX --target=sh3eb-elf --with-multilib-list=m3,m4-nofpu --enable-languages=c,c++ --without-headers --with-newlib --disable-nls --program-prefix=sh-elf-
Citer : Posté le 22/10/2020 13:14 | #
Non, il faut recompiler
Citer : Posté le 22/10/2020 13:15 | #
SH3 target works with SH4 CPUs, you can't use SH4 target with newlib