Difference between revisions of "Trash Fr:Paquets Buildroot"

From ArmadeusWiki
Jump to: navigation, search
(Ajouter le nouveau paquet à la distribution)
(Intégration du paquet dans Buildroot)
Line 46: Line 46:
  
  
Après avoir réussi à faire fonctionner son paquet/application, ajoutez une référence à package/toto/Config.in après avoir sauvé l'original dans buildroot/package/config.in et lancer la config buildroot:
+
Après avoir réussi à faire fonctionner son paquet/application, ajoutez une référence à package/toto/Config.in après avoir sauvé l'original dans buildroot/package/config.in :
 
  $ cp buildroot/package/Config.in  buildroot/package/Config.org
 
  $ cp buildroot/package/Config.in  buildroot/package/Config.org
 +
Faire les modifications dans Config.in et lancer la config buildroot
 
  $ make menuconfig
 
  $ make menuconfig
 
Choisir le package dans package, sauver la config et réessayer l'install:
 
Choisir le package dans package, sauver la config et réessayer l'install:

Revision as of 17:52, 15 May 2008

Sur cette page vous apprendrez à ajouter un nouveau paquet ou une nouvelle application dans la distribution Buildroot d'armadeus

Travail préparatoire

$ mkdir buildroot/package/toto
  • 4] Dans ce répertoire créer un fichier Makefile "toto.mk" et un fichier de configuration "Config.in". Pour ces fichiers s'inspirer par exemple de ceux présent dans le package sdl/
  • 5] Modifier le fichier Config.in afin qu'il corresponde à la description du package Toto:


  • 6] Modifier le fichier toto.mk

Ce Makefile contient plusieurs étapes avec à chaque fois une cible associée:

  • Téléchargement du soft
  • Décompression de l'archive
  • Patchage des sources si nécessaire
  • configuration des sources
  • compilation
  • installation dans le rootfs

Ce makefile doit aussi contenir une cible toto-clean pour nettoyer les sources après une compile et une cible toto-dirclean afin de supprimer le répertoire toto définitivement de la compilation

Tester la compilation du paquet

Essayer le travail:

$ make -C buildroot/ toto

Si cela fonctionne, testez votre paquet sur une plate forme armadeus. Si tout s'est bien déroulé, allez au chapitre suivant et effectuez l'integration dans buildroot. Autrement il peut être nécessaire de faire des modifications des sources/makefile ou d'autres ... Si c'est le cas, commencez par créer un répertoire contenant l'original du paquet à modifier:

$ cd buildroot/build_arm
$ cp -Rf toto toto.org 

Faites le portage nécessaire dans le répertoire toto pour obtenir le paquet qui va bien... Une fois ce dur labeur terminé il est probablement nécessaire de créer un ou plusieurs patches :

$  diff -rup toto.org/fichier toto/fichier > ../package/toto/toto.0.patch

Ce sont ces patches qui serons appliqués par le fichier toto.mk. Sauvez tout d'abord votre travail, puis refaites le test de bon fonctionnement.

$ mv toto toto.ok
$ cd ../..
$ make -C buildroot/ toto

Si tout va bien, effacez les répertoires buildroot/build_arm/toto.org et buildroot/build_arm/toto.ok désormais inutiles.

Intégration du paquet dans Buildroot

Après avoir réussi à faire fonctionner son paquet/application, ajoutez une référence à package/toto/Config.in après avoir sauvé l'original dans buildroot/package/config.in :

$ cp buildroot/package/Config.in  buildroot/package/Config.org

Faire les modifications dans Config.in et lancer la config buildroot

$ make menuconfig

Choisir le package dans package, sauver la config et réessayer l'install:

$ make toto-dirclean
$ make 

Une fois que tout cela fonctionne, il ne reste plus qu'à créer le patch de configuration de buildroot:(fichier buildroot/package/Config.in) avec la même méthode que précédement

$ diff -rup buildroot/package/Config.org  buildroot/package/Config.in > patches/numero_buildroot_nompaquet.diff

Ajouter le nouveau paquet à la distribution

Il faut donc rajouter tous les fichiers crées dans buildroot/package/toto sous SVN, ainsi que le patch de configuration de buildroot

$ svn add -N fichiers
$ svn commit -m [BUILDROOT PACKAGE] Adding an usefull toto package  files --non-interactive 


Eventuellement, testez une vue toute neuve ! ......