Les détails sur ce paquet sont situés dans Section 10.7.5, “Contenu de Glibc.”
Le paquet Glibc contient la bibliothèque C principale. Cette bibliothèque fournit toutes les routines de base pour allouer de la mémoire, rechercher dans des répertoires, ouvrir et fermer des fichiers, les lire et les écrire, gérer les chaînes, faire de la recherche de motifs, faire de l'arithmétique etc.
Notez que toute autre méthode de construire Glibc que celle suggérée dans ce livre met en péril la stabilité du système.
Désactivez l'édition d'un lien vers libgcc_eh
:
patch -Np1 -i ../glibc-2.7-libgcc_eh-1.patch
Le correctif suivant corrige un problème qui peut causer des erreurs de segmentation à l'exécution de localdef :
patch -Np1 -i ../glibc-2.7-localedef_segfault-1.patch
The following patch ensures that memcpy_chk, mempcpy_chk, and memset_chk are defined for i586.
patch -Np1 -i ../glibc-2.7-i586_chk-2.patch
La documentation de Glibc recommande de construire Glibc en dehors du répertoire des sources dans un répertoire de construction dédié :
mkdir -v ../glibc-build cd ../glibc-build
Vous devez ajouter les lignes suivantes à config.cache
pour que Glibc supporte NPTL :
echo "libc_cv_forced_unwind=yes" > config.cache echo "libc_cv_c_cleanup=yes" >> config.cache
Préparez la compilation de Glibc :
BUILD_CC="gcc" CC="${CLFS_TARGET}-gcc" \ AR="${CLFS_TARGET}-ar" RANLIB="${CLFS_TARGET}-ranlib" \ CFLAGS="-march=$(cut -d- -f1 <<< $CLFS_TARGET) -mtune=generic -g -O2" \ ../glibc-2.7/configure --prefix=/tools \ --host=${CLFS_TARGET} --build=${CLFS_HOST} \ --disable-profile --enable-add-ons \ --with-tls --enable-kernel=2.6.0 --with-__thread \ --with-binutils=/cross-tools/bin --with-headers=/tools/include \ --cache-file=config.cache
The meaning of the new configure options:
BUILD_CC="gcc"
Ceci règle GCC pour qu'il utilise le compilateur actuel de notre système. On l'utilise pour créer les outils dont Glibc se sert pendant sa construction.
CC="${CLFS_TARGET}-gcc"
Ceci oblige Glibc à utiliser le compilateur GCC que nous avons construit pour notre architecture cible.
AR="${CLFS_TARGET}-ar"
Ceci oblige Glibc à utiliser l'outil ar que nous avons construit pour notre architecture cible.
RANLIB="${CLFS_TARGET}-ranlib"
Ceci oblige Glibc à utiliser l'outil ranlib que nous avonsconstruit pour notre architecture cible.
CFLAGS="-march=$(cut -d- -f1 <<<
$CLFS_TARGET) -mtune=generic -g -O2"
Forces Glibc to optimize for our target system.
--disable-profile
Ceci construit les bibliothèques sans informations de profilage. N'utilisez pas cette option si le profiling est nécessaire sur les outils temporaires.
--enable-add-ons
Ceci dit à Glibc d'utiliser toutes les extensions disponibles.
--with-tls
Ceci dit à Glibc d'utiliser Thread Local Storage.
--enable-kernel=2.6.0
Ceci dit à Glibc de compiler la bibliothèque avec le support pour les noyaux Linux 2.6.x.
--with-__thread
Ceci dit à Glibc d'utiliser __thread pour la construction de libc et de libpthread.
--with-binutils=/cross-tools/bin
Ceci dit à Glibc d'utiliser les Binutils spécifiques à notre architecture cible.
--with-headers=/tools/include
Ceci dit à Glibc de se compiler avec les en-têtes récemment
installées dans le répertoire /tools
, afin qu'il sache exactement quelles
fonctionnalités a le noyau et qu'il puisse s'optimiser en
conséquence.
--cache-file=config.cache
Ceci dit à Glibc d'utiliser un fichier de cache préfabriqué.
Pendant cette étape, il se pourrait que les avertissements suivants apparaissent :
configure: WARNING: *** These auxiliary programs are missing or *** incompatible versions: msgfmt *** some features will be disabled. *** Check the INSTALL file for required versions.
L'absence ou l'incompatibilité du programme msgfmt n'est en général pas gênante. Ce programme msgfmt fait partie du paquet Gettext que la distribution hôte devrait fournir.
Compilez le paquet :
make
Installez le paquet :
make install
Les détails sur ce paquet sont situés dans Section 10.7.5, “Contenu de Glibc.”