Linux:重走LFS之路:(四) 工具链编译-1

Linux scott 295℃ 0评论

经过了充分的准备工作之后,我们要来着手工具链的编译。LFS不能直接使用宿主系统的编译器和库进行编译,而是用宿主系统的编译器和库再编译出来一份编译器和库,然后二次编译编译器和库,最后才能用最终的编译器来编译构建LFS系统。所以我们现在需要做的是来编译这些工具。

Linux:重走LFS之路:(四) 工具链编译-1

Linux:重走LFS之路:(四) 工具链编译-1

(题图来自: techradar.com)

这些工具的编译比较冗长,所以可能需要数篇的篇幅来记录这些过程。

首先需要创建一个目录来安置这些工具

mkdir -v $LFS/tools

然后为了方便,我们在根目录做了个软连接 /tools -> $LFS/tools

sudo ln -sv $LFS/tools /tools
Linux:重走LFS之路:(四) 工具链编译-1

Linux:重走LFS之路:(四) 工具链编译-1

这时候有个坑,LFS 7.7官方文档上写的命令是ln -sv $LFS/tools /,但是事实上在Debian 7.7版本实测,酱紫可能会有问题,就像这样

Linux:重走LFS之路:(四) 工具链编译-1

Linux:重走LFS之路:(四) 工具链编译-1

接下来为了避免使用权限大的账号误操作造成宿主机损失,新建一个lfs账户,加入lfs组,并且将$LFS下的src和tools两个目录属主都改为lfs。

sudo groupadd lfs
sudo useradd -s /bin/bash -g lfs -m -k /dev/null lfs
sudo passwd lfs
sudo chown -v lfs $LFS/tools
sudo chown -Rv lfs $LFS/src
Linux:重走LFS之路:(四) 工具链编译-1

Linux:重走LFS之路:(四) 工具链编译-1

这里还有一个坑,LFS 7.7官方文档上的原命令是chown -v lfs $LFS/src,可是我们已经下载完的文件都在那里面,会没权限操作的,所以需要加上R参数来递归修改文件属主。最后用su – lfs就可以切换到lfs账户来操作啦。

切换到lfs账户之后,我们需要建立这个账户的环境变量

vi ~/.bashrc

我们来写一个环境变量文件

HOME=$HOME
TERM=$TERM
PS1=’${debian_chroot:+($debian_chroot)}[33[01;31m][A][33[01;33m]u[33[00m]@[33[01;32m]h:[33[01;34m]w[33[00m]$ ‘
set +h
umask 022
LFS=/mnt/lfs
LC_ALL=POSIX
LFS_TGT=$(uname -m)-lfs-linux-gnu
PATH=/tools/bin:/bin:/usr/bin
export LFS LC_ALL LFS_TGT PATH
Linux:重走LFS之路:(四) 工具链编译-1

Linux:重走LFS之路:(四) 工具链编译-1

然后加载这个环境变量文件,并且查看一下是不是真的将环境变量都设置上了

source ~/.bashrc
export
Linux:重走LFS之路:(四) 工具链编译-1

Linux:重走LFS之路:(四) 工具链编译-1

事实证明我们的操作是有效的呃……

此时是有一个编译选项的,我起的虚拟机是单核的就无所谓了。如果你用了多核机器来做LFS,那么可以通过-j2参数来加速make,或者设置这样一个环境变量

export MAKEFLAGS=’-j 2′

现在为了让目录简单一点,我们需要把源码包从$LFS/src/lfs里面挪到$LFS/src里面

mv $LFS/src/lfs/* $LFS/src/

接下来我们进行工具编译

首先调整当前路径到$LFS/src

cd $LFS/src

解压binutils,开始进行binutils的第一遍编译

tar jxvf binutils-2.25.tar.bz2

进入binutils源码目录

cd binutils-2.25

我们为了保持源码目录的洁净和区分编译文件,会将每个软件新建一个构建目录来配置和编译,而非从源码目录直接编译,格式如{softname}-build

从$LFS/src/binutils-2.25平级建立binutils构建目录并进入该目录

mkdir -v ../binutils-build
cd ../binutils-build/

加入编译选项来配置binutils

../binutils-2.25/configure 
–prefix=/tools 
–with-sysroot=$LFS 
–with-lib-path=/tools/lib 
–target=$LFS_TGT 
–disable-nls 
–disable-werror

编译好的binutils不着急直接安装,因为根据官方文档的提示,我们的机器架构是x86_64,此时需要建立个库目录,然后做个软连接

case $(uname -m) in
    x86_64) mkdir -v /tools/lib && ln -sv lib /tools/lib64 ;;
esac

建立完成之后,就可以安装啦

make install

回到$LFS/src目录,继续来解压并第一遍编译GCC,不过GCC稍微复杂一点,因为它需要三个包的支持,GMP, MPFR和MPC。

tar jxvf gcc-4.9.2.tar.bz2
cd gcc-4.9.2
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

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

sed -i ‘/k prot/agcc_cv_libc_provides_ssp=yes’ gcc/configure

准备完毕,下面依旧建立构建目录,并且开始配置和构建

mkdir -v ../gcc-build
cd ../gcc-build

../gcc-4.9.2/configure 
–target=$LFS_TGT 
–prefix=/tools 
–with-sysroot=$LFS 
–with-newlib 
–without-headers 
–with-local-prefix=/tools 
–with-native-system-header-dir=/tools/include 
–disable-nls 
–disable-shared 
–disable-multilib 
–disable-decimal-float 
–disable-threads 
–disable-libatomic 
–disable-libgomp 
–disable-libitm 
–disable-libquadmath 
–disable-libsanitizer 
–disable-libssp 
–disable-libvtv 
–disable-libcilkrts 
–disable-libstdc++-v3 
–enable-languages=c,c++

make
make install

除了三个支持包和前置的一些设置之外,gcc编译就没啥新鲜的了,编译安装就是了。

接下来继续回到$LFS/src解压和编译安装Linux API Headers

tar -xf linux-3.19.tar.xz
cd linux-3.19
make mrproper
make INSTALL_HDR_PATH=dest headers_install
cp -rv dest/include/* /tools/include

Linux API Headers安装完成

这里有意思的是mrproper,其实和make clean的功能差不多,但是比clean的范围要大。

来源:http://www.haopingrui.cn/?p=83

转载请注明:osetc.com » Linux:重走LFS之路:(四) 工具链编译-1

喜欢 (0)or分享 (0)
发表我的评论
取消评论

表情

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址