Changing the CHOST variable/fr

Ce document explique comment changer la variable CHOST  d'un système existant.

Introduction
Changer la variable CHOST est un problème délicat qui peut sérieusement mettre en péril votre système. Alors, pourquoi faire un guide sur ce sujet ?

Il existe des situations où changer CHOST est inévitable, par exemple quand vous voulez mettre glibc à jour vers la version  2.4 qui ne supporte que nptl et que vous vous rendez compte que votre CHOST est i386, ce qui rend l'utilisation de nptl impossible. Dans un tel cas, vous n'avez guère d'options et changer CHOST en est une.

Même si vous suivez ces instructions, des problèmes peuvent surgir, c'est pourquoi vous devez les lire et les exécuter très prudemment. Dans cet exemple la variable CHOST sera changée de i386 en i686, si votre changement est différent, bien-sûr, adaptez les commandes en conséquence.

Compiler les paquets
Pour vous lancer dans le changement de la variable CHOST, éditez le fichier et changer la valeur CHOST selon votre besoin. Ensuite, recompilez les paquets suivants dans l'ordre indiqué :

Vérifier que tout fonctionne
Maintenant, il est temps de vous assurer que les réglages de   et de   sont sains et que vous n'avez aucun résidu dans.

La sortie de   et de    devrait ressembler à ce qui suit (peut différer selon votre version de gcc et de chost, dans ce cas, il s'agit de gcc 4.1.1 et de i686) :

Ensuite, vérifiez s'il y a des références à l'ancienne variable CHOST dans  :

Avant d'effacer le fichier, vérifions que des fichiers avec la nouvelle variable CHOST existent :

Cela paraît bon car il doit toujours n'y avoir qu'un seul fichier pour  dans  (05gcc dans notre exemple). Supprimons donc celui avec les mauvaises références :

Cela est aussi vrai pour   - s'il existe un fichier supplémentaire, cherchez celui qui est obsolète et supprimez le. Ensuite vérifiez votre.

Celui-ci paraît bon, ces deux fichiers devraient réellement être présents. Il est temps de se déplacer dans le répertoire gcc.

et sont corrects, mais  est un autre résidu qui doit être supprimé.

Maintenant exécutez les commandes suivantes pour mettre votre environnement à jour.

Puis vérifiez que tout est correctement réglé :

Si vous trouvez encore quelque chose, vous avez probablement manqué quelques fichiers, essayez de les repérer avant d'aller plus loin.

Terminer le changement
Now it is necessary to re-emerge  and run. Make sure to use the correct gcc version (your current one, 4.1.1 here) and pass your old architecture (i386 here) as argument. Replace $CHOST with your new CHOST, and  with your gcc version. This example assumes a CHOST of i686.

Vous pouvez recompiler tous vos paquets :

Maintenant, bien qu'en théorie cela ne devrait pas être nécessaire, mais nous ne pouvons le garantir à 100%, recompilez votre cible world. J'ai entendu dire que quelques paquets au moins, nécessitaient cette re-compilation ; aussi faites ceci :

All packages using perl install to the CHOST directory and hence need remerging. In case you haven't installed, you will need to install  first.

Si vous rencontrez d'autres paquets qui nécessitent la recompilation, faites le savoir à l'auteur de ce document.

Problèmes courants
Lorsque vous mettez à jour gcc de la version 3.3 vers la version 4.1 en même temps que vous changez la variable CHOST (s.v.p. ne faites ça en aucun cas), quelques utilisateurs ont fait état de paquets cassés qui nécessitent une recompilation, comme par exemple groff et courier :

Message d'erreur

Ceci se produit car pendant la mise à jour, la variable CHOST ne correspond pas exactement à CTARGET et que le compilateur suppose qu'il s'agit d'une compilation croisée. En conséquence, LDPATH n'est pas inséré dans, ce qui conduit à cette erreur.

Please see our GCC upgrade guide for what needs to be rebuilt after a GCC upgrade.

Dans quelques rares cas, ceci peut casser d'anciennes versions de python également. On peut régler ce problème en ajoutant  (changez selon votre CHOST et votre version de  gcc ) à

Retour d'expérience
That should be all, feedback (both if it worked, failed or other problems were encountered) is welcome, please send an email to or post to this forums thread. Much in this howto comes from vapier, thanks for your help!

Remerciements
Nous tenons à remercier les auteurs et éditeurs suivants pour leur contribution à ce guide :


 * Wernfried Haas
 * Mike Frysinger
 * Chris White