Les détails sur ce paquet sont situés dans Section 6.17.2, « Contenu de GCC. »
Le paquet GCC contient la collection de compilateurs GNU, qui inclut les compilateurs C et C++.
Notre première construction de GCC a installé deux en-têtes
internes au système. En principe, l'une d'entre elles, limits.h
incluera l'en-tête limits.h
du système correspondante dans ce cas,
/tools/include/limits.h
. Cependant,
au moment de la première construction de gcc, /tools/include/limits.h
n'existait pas, donc
l'en-tête interne qu'a installée GCC est un fichier partiel, à
moitié-rempli et il n'inclut pas fonctions étendues de l'en-tête du
système. Ceci s'adaptait à la construcsion de la libc temporaire
mais la construction de GCC exige maintenant l'en-tête interne
complète. Créez une version complète de l'en-tête interne en
utilisant une commande identique à ce que fait le système de
construction de GCC en temps normal :
cat gcc/limitx.h gcc/glimits.h gcc/limity.h > \ `dirname $($LFS_TGT-gcc -print-libgcc-file-name)`/include-fixed/limits.h
Pour les machines x86, une construction bootstrap de GCC utilise le
drapeau -fomit-frame-pointer
du
compilateur. Les constructions non-bootstrap suppriment ce drapeau
par défaut, l'objectif serait d'obtenir un compilateur qui est
exactement le même que si nous étions bootstrapés. Appliquez la
commande sed suivante
pour obliger la construction à utiliser le drapeau :
cp -v gcc/Makefile.in{,.tmp} sed 's/^T_CFLAGS =$/& -fomit-frame-pointer/' gcc/Makefile.in.tmp \ > gcc/Makefile.in
Une fois encore, modifiez l'emplacement de l'éditeur de liens
dynamique par défaut de GCC pour utiliser celui installé dans
/tools
.
for file in \ $(find gcc/config -name linux64.h -o -name linux.h -o -name sysv4.h) do cp -uv $file{,.orig} sed -e 's@/lib\(64\)\?\(32\)\?/ld@/tools&@g' \ -e 's@/usr@/tools@g' $file.orig > $file echo ' #undef STANDARD_STARTFILE_PREFIX_1 #undef STANDARD_STARTFILE_PREFIX_2 #define STANDARD_STARTFILE_PREFIX_1 "/tools/lib/" #define STANDARD_STARTFILE_PREFIX_2 ""' >> $file touch $file.orig done
Comme dans la première construction de GCC, il a besoin de GMP, de MPFR et MPC. Déballez les archives tar et déplacez-les dans les répertoires nommés comme il le faut :
tar -Jxf ../mpfr-3.1.1.tar.xz mv -v mpfr-3.1.1 mpfr tar -Jxf ../gmp-5.0.5.tar.xz mv -v gmp-5.0.5 gmp tar -zxf ../mpc-1.0.tar.gz mv -v mpc-1.0 mpc
De nouveau, créez un répertoire de construction séparé :
mkdir -v ../gcc-build cd ../gcc-build
Avant de commencer la construction de GCC, rappelez-vous de désinitialiser toute variable d'environnement surchargeant les options d'optimisation par défaut.
Maintenant, préparez la compilation de GCC :
CC=$LFS_TGT-gcc \ AR=$LFS_TGT-ar \ RANLIB=$LFS_TGT-ranlib \ ../gcc-4.7.1/configure \ --prefix=/tools \ --with-local-prefix=/tools \ --with-native-system-header-dir=/tools/include \ --enable-clocale=gnu \ --enable-shared \ --enable-threads=posix \ --enable-__cxa_atexit \ --enable-languages=c,c++ \ --disable-libstdcxx-pch \ --disable-multilib \ --disable-bootstrap \ --disable-libgomp \ --with-mpfr-include=$(pwd)/../gcc-4.7.1/mpfr/src \ --with-mpfr-lib=$(pwd)/mpfr/src/.libs
Voici la signification des nouvelles options de configure :
--enable-clocale=gnu
Cette option nous assure que le bon modèle de locale est sélectionné pour les bibliothèques C++ sous toutes les circonstances. Si le script configure trouve la locale de_DE installée, il sélectionnera le bon modèle de locale gnu. Néanmoins, si la locale de_DE n'est pas installée, il existe un risque de construire des bibliothèques C++ incompatibles avec ABI (Application Binary Interface) à cause du choix d'un mauvais modèle générique de locale.
--enable-threads=posix
Ceci active la gestion des exceptions C++ pour le code multi-threadé.
--enable-__cxa_atexit
Cette option autorise l'utilisation de __cxa_atexit
, plutôt que atexit
, pour enregistrer les destructeurs
C++ des objets statiques locaux et globaux. Cette option est
essentielle pour la gestion des destructeurs en compatibilité
complète avec les standards. Il affecte aussi l'ABI C++ et
donc résulte en des bibliothèques partagées et des programmes
C++ interopérables avec les autres distributions Linux.
--enable-languages=c,c++
Cette option garantie que les compilateurs C et C++ seront construits.
--disable-libstdcxx-pch
Ce commutateur empêche la construction de l'en-tête
précompilé (PCH) de libstdc++
.
Il prend beaucoup d'espace et nous n'en avons aucune utilité.
--disable-bootstrap
Pour les constructions natives de GCC, on a par défaut une compilation "bootstrap". Elle ne fait pas que compiler GCC, mais elle le compile plusieurs fois. Elle utilise les programmes compilés dans une première étape pour se compiler une seconde fois, puis une troisième fois à nouveau. Les deuxième et troisième passages sont comparés pour garantir qu'elle peut se reproduire facilement. Cela implique aussi qu'elle a été compilée correctement. Néanmoins, la méthode de compilation LFS devrait fournir un compilateur solide sans qu'il soit nécessaire de bootstraper chaque fois.
Compilez le paquet :
make
Installez le paquet :
make install
En touche finale, créez un lien symbolique. Beaucoup de programmes et de scripts lance cc au lieu de gcc, qui est utilisé pour conserver des programmes génériques, utilisables donc sur n'importe quel type de système où le compilateur C n'est pas toujours installé. L'exécution de cc laisse l'administrateur du système décider quel compilateur C installer :
ln -vs gcc /tools/bin/cc
A ce stade, il est impératif de s'arrêter et de s'assurer que les fonctions de base (compilation et édition de liens) du nouvel ensemble d'outils fonctionnent comme prévu. Pour effectuer un test de propreté, lancez les commandes suivantes :
echo 'main(){}' > dummy.c cc dummy.c readelf -l a.out | grep ': /tools'
Si tout fonctionne correctement, il ne devrait pas y avoir d'erreurs et la sortie de la dernière commande aura la forme :
[Requesting program interpreter: /tools/lib/ld-linux.so.2]
Remarquez que /tools/lib
ou
/tools/lib64
pour les machines 64
bits apparaît comme préfixe de l'éditeur de liens dynamiques.
Si l'affichage diffère ou s'il n'y a aucun affichage, alors
quelque chose ne se passe pas bien. Enquêtez et tracez vos étapes
pour trouver où se cache le problème et comment le corriger. Ce
problème doit être corrigé avant de continuer. Tout d'abord,
relancez la vérification de propreté en utilisant gcc au lieu de cc. Si cela fonctionne, le lien
symbolique /tools/bin/cc
est
manquant. Installez le lien symbolique comme indiqué ci-dessus.
Ensuite, assurez-vous que le PATH
est
correct. Ceci se vérifie en lançant echo $PATH et en vérifiant que
/tools/bin
est en tête de la liste.
Si le PATH
est mauvais, cela pourrait
signifier que vous n'êtes pas connecté en tant qu'utilisateur
lfs
ou que quelque chose s'est
mal passé dans Section 4.4,
« Configurer l'environnement. ».
Une fois que tout va bien, nettoyez les fichiers de test ::
rm -v dummy.c a.out
Les détails sur ce paquet sont situés dans Section 6.17.2, « Contenu de GCC. »