GCC 软件包包含 GNU 编译器集合,其中有 C 和 C 编译器。
第一次编译 GCC 的时候安装了一些内部系统头文件。
其中的一个 limits.h 会反过来包括对应的系统头文件 limits.h, 在我们的例子中,是 /tools/include/limits.h。
但是,第一次编译 gcc 的时候 /tools/include/limits.h 并不存在,因此 GCC 安装的内部头文件只是部分的自包含文件, 并不包括系统头文件的扩展功能。这足以编译临时 libc,但是这次编译 GCC 要求完整的内部头文件。
首先,切换到 lfs
用户下:
su - lfs
确保环境变量已生效,并且解压软件包
代码语言:javascript复制echo $LFS
cd $LFS/sources
tar xf gcc-4.9.2.tar.bz2
cd gcc-4.9.2
使用和正常情况下 GCC 编译系统使用的相同的命令创建一个完整版本的内部头文件:
代码语言:javascript复制cat gcc/limitx.h gcc/glimits.h gcc/limity.h >
`dirname $($LFS_TGT-gcc -print-libgcc-file-name)`/include-fixed/limits.h
再一次更改 GCC 的默认动态链接器的位置,使用安装在 /tools 的那个:
代码语言:javascript复制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
和第一次编译 GCC 一样,它要求 GMP、MPFR 和 MPC 软件包。 解压 tar 包并把它们重名为到所需的文件夹名称:
代码语言:javascript复制tar -xf ../mpfr-3.1.2.tar.xz
mv -v mpfr-3.1.2 mpfr
tar -xf ../gmp-6.0.0a.tar.xz
mv -v gmp-6.0.0 gmp
tar -xf ../mpc-1.0.2.tar.gz
mv -v mpc-1.0.2 mpc
再次创建独立的编译文件夹:
代码语言:javascript复制mkdir -v ../gcc-build
cd ../gcc-build
准备编译 GCC:
代码语言:javascript复制CC=$LFS_TGT-gcc
CXX=$LFS_TGT-g
AR=$LFS_TGT-ar
RANLIB=$LFS_TGT-ranlib
../gcc-4.9.2/configure
--prefix=/tools
--with-local-prefix=/tools
--with-native-system-header-dir=/tools/include
--enable-languages=c,c
--disable-libstdcxx-pch
--disable-multilib
--disable-bootstrap
--disable-libgomp
编译软件包:
代码语言:javascript复制make
安装软件包:
代码语言:javascript复制make install
作为画龙点睛,这里创建一个符号链接:
代码语言:javascript复制ln -sv gcc /tools/bin/cc
检查是否安装成功:
代码语言:javascript复制echo 'main(){}' > dummy.c
cc dummy.c
readelf -l a.out | grep ': /tools'
???? 注意:如果上述执行返回结果是:[Requesting program interpreter: /tools/lib64/ld-linux-x86-64.so.2]
,则代表正常。
安装完成后清理工作:
代码语言:javascript复制rm -v dummy.c a.out
cd ..
rm -rf gcc-build
rm -rf gcc-4.9.2