更新日志(具体更新内容见文末)
2008年7月7日:增加内核支持显示UTF-8编码文字 2008年7月6日:修改笔误两处 2008年3月16日:修改笔误一处 2008年3月8日:修改命令一处 2008年3月3日:修改命令一处 2008年2月12日:修改/etc/profile的内容 2008年2月12日:修改笔误一处 2008年2月10日:本文发布。 前言: 这是本文的第二版本,据第一版本发布已经将近两年的时间,第一版针对LFS-6.1.1的手册进行讲解,LFS-6.3相对于LFS-6.1.1方法上有了一些变化,软件包也大量更新,为了方便新手能够快速进入状态,决定再次撰写此文的第二版,并针对LFS-6.3来编写。 本文在内容和形式上完全继承第一版本的风格,内容上根据版本进行变化,但整体没有本质的变化,在这里首先感谢哪些在第一版中提出意见和问题的网友,使得本文变的越来越完善。 LFS是一部非常好的制作一个完整的操作系统的手册,但LFS是属于指导性的手册,因此它默认的前提条件是具备一定的Linux使用经验的用户群,所以它在每个软件包的安装部分只给出了在目录中的全部操作指令,而对于解压缩之类的则交给用户自己去解决,但对于很多第一次使用LFS的用户往往会出现一些不清楚某条命令应该是在哪里执行的问题,本文力图从实例上来解释这些问题。 本文虽然是采用VMWare Workstation 5.5的环境下制作的,但仍然符合使用真实机器上的过程,只是会在某些地方要根据具体机器进行更改,文中会在这些地方做出说明。 使用WMWare来写这篇文章是为了说明方便,因为VMWare在各种不同机器环境下模拟的虚拟设备几乎相同,所以用它来说明一些需要实际例子才说的清楚的地方非常合适,而且用VMWare来做即使出错也不会对真实的系统造成破坏,很适合新手使用,唯一的缺点就是速度慢了些,一般只有真实机器的一半左右的速度。 本文力争完成一个完整的制作命令,可以根据本文提供的命令顺序输入就可以完成LFS了,通常命令表示为
代码:
恢复工作的方法更加适合在真实机器上制作LFS的朋友,如果使用VMWare也可以直接使用VMWare的暂停功能来保存现场,继续的时候恢复现场就可以了。 更新,由于篇幅比较长所以难免出现一些错误或者笔误,也有可能加入新内容,因此难免会进行修正或增删一些内容,如果本文被转载可以在www.linuxsir.org的LFS版中或者在本人的Blog中查看最新版本。 linuxsir:http://www.linuxsir.org/bbs/showthread.php?t=322894 我的Blog:http://youbest.cublog.cn 如须转载请注明作者为孙海勇(冲天飞豹),并提供转载出处。 准备工作: 下载LiveCD的ISO文件(因为在制作本文时最新正式版只有6.3-r2145下载):http://ftp.osuosl.org/pub/lfs-livecd/lfslivecd-x86-6.3-r2145.iso 刻录ISO文件到光盘上,如果你是用真实机器当然少不了这步,不过如果你用VMWare的话,就可以直接使用ISO文件了。 以VMWare Workstation 5.5为例(真实机器可跳过此部分) 选择File->New->Virtual Machine...启动向导 选择Custom,并选择New-Workstation 5然后在选择Guest operating system里选择Linux,在Version里选择Other Linux 2.6.x kernel 存放目录、处理器数量和内存大小根据实际情况,建议内存不得小于128M,最好256M以上 相关知识点: LFS-6.3采用了GCC4.1.2,如果使用128M编译GCC4.x.x话就需要使用swap了,但如果配置了256M就可以在没有swap的情况下完成编译,所以条件允许的情况下使用256M。 Network connection里选择Use network address translation(NAT) SCSI Adpters选择默认的LSI Logic就可以了 注意点: 这里选择的磁盘类型对于最后编译内核使用选项是有影响的,我在本文的第一版中使用BusLogic来建立系统,因此这里选择使用LSI Logic来用,如果使用BusLogic的话可以参考本文第一版中的内核编译选项来代替后面的内核选项部分。 选择Create a new virtual disk 在Virtual Disk Type这步比较重要,你可以选择IDE也可以选择SCSI,但这里的选择直接影响到最后编译内核时的选项。这里以选择IDE为例子。 相关知识点: 如果选择了IDE,则内核的默认设置就可以支持,但如果选择了SCSI,就必须在内核中加入对SCSI Adpters的支持,因为前面选择了LSI Logic,所以内核中就必须加入对LSI Logic的支持,否则将无法启动,相关部分在最后的内核编译部分有说明。 不过这里我建议选择使用IDE,一方面方便驱动,另外似乎LFS-6.3-r2145尚不能支持LSI Logic的SCSI磁盘,用该LiveCD启动后可能无法识别出硬盘来。 对于磁盘大小,使用4G足够编译LFS了,但如果你打算编译更多的BLFS,这里可以考虑适当的增加一些大小,如果磁盘空间比较富裕就用默认的8G好了。 完成向导后在虚拟机的界面里选择Edit virtual machine settings,将CD-ROM改为Use ISO image,然后选择LiveCD的ISO文件,如果你已经刻录好了光盘,将光盘放入光驱就行了。 点Start this virtual machine开是虚拟机 由于虚拟盘上没有任何信息,因此将自动从LiveCD中启动,在启动过程中会出现选择时区等信息,你可以按照实际情况选择,也可以按照默认选择,简单点就是等待一会系统会自动进行选择。这里我选择时区为Asia/Shanghai,选择本地语言为Chinese (Simplified, UTF-8),其它的都按默认选择了。 启动完成LiveCD后就开始建造自己的LFS的历程了。 这里先介绍以下两个LiveCD下的重要目录 /usr/share/LFS-BOOK-6.3-HTML目录存放的就是LFS手册了 /lfs-sources里面存放的就是建造LFS所需要的源码包,不需要到处下软件了。 磁盘分区: 输入命令:
代码:
这里可以按照你自己的需要的分区,这里我按照设置一个根分区和一个交换分区为例,交换分区占用512M,其余的全部分给根分区。 磁盘分区 作用 /dev/hda1 swap /dev/hda2 作为目标系统根目录 保存退出后进行磁盘分区的格式化
代码:
磁盘格式化一定要在磁盘分区未进行加载前进行。 mkswap是用于将磁盘分区格式化为交换分区的命令。 这里我将/dev/hda2格式化了为Xfs格式,如果你喜欢其它格式的文件系统,你可以使用相应的命令来格式化。 注意:这里要根据实际情况建立和设置分区,如果你不太清楚这个问题,请先不要开始,否则可能造成难以恢复的损失!(这里只是根据VMWare里面的情况做的例子,在VMWare中相对安全些,建议初学者在虚拟机中开始。) 如果你的内存不太大,想在编译期间就使用上交换分区的话,可使用下面的命令激活交换分区 swapon /dev/hda1 相关知识点: swapon用于激活交换分区 swapoff用于将激活的交换分区停用 可以通过free命令来查看当前的内存使用情况 创建LFS的“创作基地”
代码:
export LFS=/mnt/lfs这条命令的作用是为了后面引用“创作基地”的绝对路径方便而设置LFS这样的环境变量。 加载/dev/hda2到“创作基地”
代码:
创建必要的目录并设置属性 创建源代码编译用目录
代码:
chmod a+wt是将目录或文件的属性设置为1777,这样任何人都可以对其进行读写。 创建工具链目录
代码:
ln -sv $LFS/tools执行后应该会输出 `/tools' -> `/mnt/lfs/tools' 表示正确。 相关知识点: 上面这两句就建立了神奇的工具链目录(是工具链目录不是工具链),这样的创建方式是为了在创建工具链和使用工具链创建目标系统的时候对于工具链的位置都是/tools,这样可保证工具链的正常使用 创建lfs用户
代码:
代码:
代码:
代码:
相关知识点: 其实如果不使用lfs用root也是能完成工具链的,不过需要对root的环境变量进行修改,还要防止因为输入错误而导致覆盖主系统下的文件,所以LFS手册中制作工具链部分就是为了解决这种意外的发生而用lfs用户来建立工具链 建立lfs用户的环境
代码:
这里面最重要的就是PATH这个参数,目的是为了能够利用工具链里面的工具制作工具链:首先查找/tools/bin下是否有需要的命令,如果没有再到/bin和/usr/bin下找,然后用/bin或/usr/bin下面的命令来帮助生成需要的命令并放在/tools/bin下,这样此消彼涨,最终可完成一个自给自足的工具链。 到此为止就可以开始工具链的制作了,不过制作LFS是一个漫长而浩大的工程,所以要一直开机直到完成有时候比较困难,特别是在机器速度比较慢的情况下,能够重新启动到最后工作的状态是很重要的。在不同的阶段重新启动并恢复状态的步骤不完全相同,所以本文会在不同的阶段讨论重新启动恢复到工作状态的方法和步骤。 从现在开始一直到第五章结束,也就是完成Stripping中间的步骤中如果重新启动的恢复步骤: 1.重新启动计算机,并从LiveCD启动 相关知识点:在VMWare中因为磁盘已经有了信息了,所以会从磁盘启动,需要在启动虚拟机中的机器时按F2进入虚拟机的虚拟BIOS,然后在BOOT中设置第一启动为CD-ROM,保存退出即可。 2.LiveCD启动过程同第一次启动选择一样。 3.加载分区 export LFS=/mnt/lfs mkdir -pv $LFS mount /dev/hda2 $LFS 4.加载交换分区(如果不想用交换分区或者没有交换分区可跳过此步骤) swapon /dev/hda1 5.建立工具链的链接 ln -sv $LFS/tools / 6.创建lfs用户 groupadd lfs useradd -s /bin/bash -g lfs -m -k /dev/null lfs passwd lfs chown -v lfs $LFS/tools chown -v lfs $LFS/sources su - lfs 7.建立lfs用户的环境 cat > ~/.bash_profile << "EOF" exec env -i HOME=$HOME TERM=$TERM PS1='/u:/w/$ ' /bin/bash EOF cat > ~/.bashrc << "EOF" set +h umask 022 LFS=/mnt/lfs LC_ALL=POSIX PATH=/tools/bin:/bin:/usr/bin export LFS LC_ALL PATH EOF source ~/.bash_profile 8.检查一下 export命令查看输出,应该是 declare -x HOME="/home/lfs" declare -x LC_ALL="POSIX" declare -x LFS="/mnt/lfs" declare -x OLDPWD declare -x PATH="/tools/bin:/bin:/usr/bin" declare -x PS1=" //u://w///$ " declare -x PWD="/home/lfs" declare -x SHLVL="1" declare -x TERM="linux" 9.进入编译目录 cd $LFS/sources 基本上就恢复工作状态了。 开始工具链的制作 进入LFS包编译目录
代码:
代码:
大家可以注意到后面所有的解包命令均使用tar xvf来完成,而不管文件的压缩方式是bz2还是gz,这是因为较新的tar程序都具有自动识别后缀名并自动调用相应的解压缩工具的能力,所以可以不需要指定压缩方式,但对于早期的tar命令则可能不具备这个功能因此需要你根据包的压缩方式来指定,如bz2使用j,gz使用z,对应上面的binutils则是tar xvjf /lfs-sources/binutils-2.17.tar.bz2 因LFS的LiveCD中提供的tar版本比较新,后面制作的tar版本也比较新,因此支持自动识别的能力,同时为了使文章的解压命令看起来比较统一方便维护(同样对于想制作成脚本的朋友也会比较方便)因此后面统一使用tar xvf来解压。 接着我们需要建立一个目录,因为binutils建议使用一个空目录来编译,所以
代码:
GCC-4.1.2 - Pass 1
代码:
Linux-2.6.22.5 API Headers
代码:
Glibc-2.5.1
代码:
这里的参数--enable-kernel=2.6.0,只是为了说明kernel的大版本,所以不需要根据实际的kernel版本来改,即使是用linux-2.6.15也一样只写2.6.0就可以了。 调整工具链
代码:
工具链的调整方法有好几种,而且不同版本GCC的specs可能会有不同,但实际上都是把specs文件中的/lib/ld-linux.so.2替换成了/tools/lib/ld-linux.so.2,所以即使有些文章在调整工具链上的命令和LFS手册上的不一样也不用太奇怪,当然也可以直接用gcc -dumpspecs导出后手工直接编辑specs文件。 测试工具链的调整 echo 'main(){}' > dummy.c cc dummy.c readelf -l a.out | grep 'tools' 如果输出大致如下 [Requesting program interpreter: /tools/lib/ld-linux.so.2] 则表示调整成功,因为所有的库已经连接到了/tools/lib下。 rm -rf a.out dummy.c 测试工具安装 说明:这部分将安装3个用于第六章各种源码包编译后的测试的工具,所以如果你不打算做make check之类的事情,那么这3个包可以不装。 Tcl-8.4.15 Expect-5.43.0 DejaGNU-1.4.4
代码:
GCC-4.1.2 - Pass 2
代码:
echo 'main(){}' > dummy.c cc dummy.c readelf -l a.out | grep 'tools' 如果输出大致如下 [Requesting program interpreter: /tools/lib/ld-linux.so.2] 则表示调整成功,因为所有的库已经连接到了/tools/lib下。 rm -rf a.out dummy.c Binutils-2.17 - Pass 2
代码:
代码:
Bash-3.2
代码:
Bzip2-1.0.4
代码:
Coreutils-6.9
代码:
Diffutils-2.8.1
代码:
Findutils-4.2.31
代码:
Gawk-3.1.5
代码:
Gettext-0.16.1
代码:
Grep-2.5.1a
代码:
Gzip-1.3.12
代码:
Make-3.81
代码:
Patch-2.5.4
代码:
Perl-5.8.8
代码:
Sed-4.1.5
代码:
Tar-1.18
代码:
Texinfo-4.9
代码:
Util-linux-2.12r
代码:
这步是可有可无的,如果你打算今后还要用/tools里面的东西,那么可以strip一下来减少占用的磁盘空间,但如果做完目标系统后就删除了,不Strip也可以,反正最后也是要删掉的。
代码:
代码:
退出lfs用户(这步不要少了)
代码:
现在你应该是处于root用户状态的,看看你的命令行提示符是不是回到了#。 从现在开始不在需要lfs用户来制作系统了,因此我们用
代码:
创建三个重要目录
代码:
代码:
这个时候也许你想睡觉关机了,那么重新开机后回到工作状态的步骤是: 1.重新启动计算机,并从LiveCD启动 2.加载分区 export LFS=/mnt/lfs mkdir -pv $LFS mount /dev/hda2 $LFS 3.加载交换分区(如果不想用交换分区或者没有交换分区可跳过此步骤) swapon /dev/hda1 相关知识点: 这时候已经制作好了工具链,因此可以不需要建立根目录下的tools链接了。 利用主系统加载几个重要的文件系统,请注意这个步骤对于后面的工作极其重要。
代码:
mount命令加载的分区在重新启动后就失效了,所以在这其中重新启动则需要重新加载。 这里为了方便使用源码包,我将光盘加载到目标系统里 mkdir $LFS/cdrom mount /dev/cdrom $LFS/cdrom 这个步骤不是必须的,如果你想使用,那么在重新启动后进入工作状态的步骤中在相应的位置上加入。 这里有一个更简单的办法,将lfs-sources里面所有源码包复制到$LFS/sources目录中,这步对于后面在第六章使用源代码将非常方便。
代码:
为了方便在制作完后的系统能够直接显示中文,这里可以从网络上下载本人写的一个显示UTF-8编码文字的内核补丁。 使用下面的命令来下载: cd $LFS/sources/ wget http://zdbr.net.cn/download/utf8-kernel-2.6.22.5-core-1.patch.bz2 wget http://zdbr.net.cn/download/utf8-kernel-2.6.22.5-fonts-1.patch.bz2 解压缩这两个补丁 bunzip2 utf8-kernel-2.6.22.5-core-1.patch.bz2 bunzip2 utf8-kernel-2.6.22.5-fonts-1.patch.bz2 Chroot到目标系统的目录下,以便不受主系统的影响来制作目标系统
代码:
这个时候如果你关机或重新启动,那么重新开机后回到工作状态的步骤是: 1.重新启动计算机,并从LiveCD启动 2.加载分区 export LFS=/mnt/lfs mkdir -pv $LFS mount /dev/hda2 $LFS 3.加载交换分区(如果不想用交换分区或者没有交换分区可跳过此步骤) swapon /dev/hda1 4.加载必要的文件系统 mount -v --bind /dev $LFS/dev mount -vt devpts devpts $LFS/dev/pts mount -vt tmpfs shm $LFS/dev/shm mount -vt proc proc $LFS/proc mount -vt sysfs sysfs $LFS/sys 5.Chroot到目标系统下 chroot "$LFS" /tools/bin/env -i / HOME=/root TERM="$TERM" PS1='/u:/w/$ ' / PATH=/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin / /tools/bin/bash --login +h 建立目标系统的目录结构
代码:
创建几个必要的链接,因为在目标系统的编译过程中,部分编译程序会用绝对路径来寻找命令或文件。
代码:
创建root及nobody用户和必要的组
代码:
重新加载bash,以使root用户起效,这样前面的提示符就不会是“I have no name!”
代码:
创建和设置几个临时文件和日志文件。
代码:
到目前为止,创建目标系统的准备工作以基本完成,下面就要开始目标系统的软件包安装了。 首先进入到源码目录下。
代码:
export LFS=/cdrom/lfs-sources 如果之前是将所有源码包复制到sources下的,则执行
代码:
从现在开始一直到第六章的Stripping Again之前,这个阶段如果你关机或重新启动,那么重新开机后回到工作状态的步骤是: 1.重新启动计算机,并从LiveCD启动 2.加载分区 export LFS=/mnt/lfs mkdir -pv $LFS mount /dev/hda2 $LFS 3.加载交换分区(如果不想用交换分区或者没有交换分区可跳过此步骤) swapon /dev/hda1 4.加载必要的文件系统 mount -v --bind /dev $LFS/dev mount -vt devpts devpts $LFS/dev/pts mount -vt tmpfs shm $LFS/dev/shm mount -vt proc proc $LFS/proc mount -vt sysfs sysfs $LFS/sys 5.Chroot到目标系统下 chroot "$LFS" /tools/bin/env -i / HOME=/root TERM="$TERM" PS1='/u:/w/$ ' / PATH=/bin:/usr/bin:/sbin:/usr/sbin:/tools/bin / /bin/bash --login +h 6.进入编译目录 cd /sources export LFS=/sources Linux-2.6.22.5
代码:
代码:
Glibc-2.5.1 在进行之前请检查一下是否glibc-2.5.1和glibc-build这两个目录已经被删除,如果没有删除请删除后在继续。
代码:
mkdir -pv /usr/lib/locale localedef -i zh_CN -f GB18030 zh_CN localedef -i zh_CN -f GBK zh_CN localedef -i zh_CN -f UTF-8 zh_CN localedef -i zh_CN -f GB2312 zh_CN localedef -i zh_HK -f UTF-8 zh_CN localedef -i zh_HK -f BIG5-HKSCS zh_CN localedef -i zh_TW -f EUC-TW zh_CN localedef -i zh_TW -f UTF-8 zh_CN localedef -i zh_TW -f BIG5 zh_CN 建立几个重要文件:
代码:
代码:
glibc的测试比较容易出现错误,比如机器慢就有可能出现超时的错误,还有一些能引起错误的LFS手册上有所提及,像超时这种错误有时候很难避免,就跳过去吧。 调整工具链
代码:
代码:
echo 'main(){}' > dummy.c cc dummy.c -v -Wl,--verbose &> dummy.log readelf -l a.out | grep '/lib' 如果显示[Requesting program interpreter: /lib/ld-linux.so.2]表示调整成功,动态库已经连接到了目标系统的/lib下。 grep -o '/usr/lib.*/crt[1in].*succeeded' dummy.log 应该显示 /usr/lib/crt1.o succeeded /usr/lib/crti.o succeeded /usr/lib/crtn.o succeeded grep -B1 '^ /usr/include' dummy.log 应该显示 #include <...> search starts here: /usr/include grep 'SEARCH.*/usr/lib' dummy.log |sed 's|; |/n|g' 应该显示 SEARCH_DIR("/tools/i686-pc-linux-gnu/lib") SEARCH_DIR("/usr/lib") SEARCH_DIR("/lib"); grep "/lib/libc.so.6 " dummy.log 应该显示 attempt to open /lib/libc.so.6 succeeded grep found dummy.log 应该显示 found ld-linux.so.2 at /lib/ld-linux.so.2 如果上面均显示正常,那么表明工具链调整成功,可以删除测试文件了 rm -v dummy.c a.out dummy.log Binutils-2.17
代码:
代码:
代码:
GCC-4.1.2
代码:
代码:
代码:
echo 'main(){}' > dummy.c cc dummy.c -v -Wl,--verbose &> dummy.log readelf -l a.out | grep 'lib' 如果显示[Requesting program interpreter: /lib/ld-linux.so.2]表示链接位置正确,动态库已经连接到了目标系统的/lib下。 grep -o '/usr/lib.*/crt[1in].*succeeded' dummy.log 应该显示 /usr/lib/gcc/i686-pc-linux-gnu/4.1.2/../../../crt1.o succeeded /usr/lib/gcc/i686-pc-linux-gnu/4.1.2/../../../crti.o succeeded /usr/lib/gcc/i686-pc-linux-gnu/4.1.2/../../../crtn.o succeeded grep -B3 '^ /usr/include' dummy.log 应该显示 #include <...> search starts here: /usr/local/include /usr/lib/gcc/i686-pc-linux-gnu/4.1.2/include /usr/include grep 'SEARCH.*/usr/lib' dummy.log |sed 's|; |/n|g' 应该显示 SEARCH_DIR("/usr/i686-pc-linux-gnu/lib") SEARCH_DIR("/usr/local/lib") SEARCH_DIR("/lib") SEARCH_DIR("/usr/lib"); grep "/lib/libc.so.6 " dummy.log 应该显示 attempt to open /lib/libc.so.6 succeeded grep found dummy.log 应该显示 found ld-linux.so.2 at /lib/ld-linux.so.2 如果上面均显示正常,那么表明工具链正常,可以删除测试文件了 rm -v dummy.c a.out dummy.log Berkeley DB-4.5.20
代码:
Sed-4.1.5
代码:
代码:
代码:
E2fsprogs-1.40.2
代码:
代码:
代码:
Coreutils-6.9
代码:
代码:
删除测试用数据:
代码:
代码:
Iana-Etc-2.20
代码:
M4-1.4.10
代码:
代码:
代码:
Bison-2.3
代码:
代码:
代码:
Ncurses-5.6
代码:
Procps-3.2.7
代码:
Libtool-1.5.24
代码:
代码:
代码:
Perl-5.8.8
代码:
代码:
代码:
Readline-5.2
代码:
Zlib-1.2.3
代码:
代码:
代码:
代码:
代码:
Autoconf-2.61
代码:
代码:
代码:
Automake-1.10
代码:
代码:
代码:
Bash-3.2
代码:
代码:
代码:
代码:
Bzip2-1.0.4
代码:
Diffutils-2.8.1
代码:
File-4.21
代码:
Findutils-4.2.31
代码:
代码:
代码:
Flex-2.5.33
代码:
代码:
代码:
代码:
代码:
GRUB-0.97
代码:
代码:
代码:
Gawk-3.1.5
代码:
代码:
代码:
Gettext-0.16.1
代码:
代码:
代码:
Grep-2.5.1a
代码:
代码:
代码:
Groff-1.18.1.4
代码:
Gzip-1.3.12
代码:
代码:
代码:
Inetutils-1.5
代码:
IPRoute2-2.6.20-070313
代码:
Kbd-1.12
代码:
Less-406
代码:
Make-3.81
代码:
代码:
代码:
Man-DB-2.4.4
代码:
代码:
代码:
Mktemp-1.5
代码:
Module-Init-Tools-3.2.2
代码:
Patch-2.5.4
代码:
Psmisc-22.5
代码:
Shadow-4.0.18.1
代码:
代码:
代码:
代码:
Sysklogd-1.4.1
代码:
代码:
代码:
Sysvinit-2.86
代码:
代码:
代码:
Tar-1.18
代码:
代码:
代码:
Texinfo-4.9
代码:
代码:
代码:
代码:
代码:
Udev-113
代码:
代码:
代码:
Util-linux-2.12r
代码:
Vim-7.1
代码:
代码:
代码:
代码:
代码:
退出chroot环境:
代码:
为Strip而进入chroot环境:
代码:
1.重新启动计算机,并从LiveCD启动 2.加载分区 export LFS=/mnt/lfs mkdir -pv $LFS mount /dev/hda2 $LFS 3.加载交换分区(如果不想用交换分区或者没有交换分区可跳过此步骤) swapon /dev/hda1 4.加载必要的文件系统 mount -v --bind /dev $LFS/dev mount -vt devpts devpts $LFS/dev/pts mount -vt tmpfs shm $LFS/dev/shm mount -vt proc proc $LFS/proc mount -vt sysfs sysfs $LFS/sys 5.Chroot到目标系统下 chroot "$LFS" /tools/bin/env -i / HOME=/root TERM="$TERM" PS1='/u:/w/$ ' / PATH=/bin:/usr/bin:/sbin:/usr/sbin / /tools/bin/bash --login Strip
代码:
代码:
代码:
1.重新启动计算机,并从LiveCD启动 2.加载分区 export LFS=/mnt/lfs mkdir -pv $LFS mount /dev/hda2 $LFS 3.加载交换分区(如果不想用交换分区或者没有交换分区可跳过此步骤) swapon /dev/hda1 4.加载必要的文件系统 mount -v --bind /dev $LFS/dev mount -vt devpts devpts $LFS/dev/pts mount -vt tmpfs shm $LFS/dev/shm mount -vt proc proc $LFS/proc mount -vt sysfs sysfs $LFS/sys 5.Chroot到目标系统下 chroot "$LFS" /usr/bin/env -i / HOME=/root TERM="$TERM" PS1='/u:/w/$ ' / PATH=/bin:/usr/bin:/sbin:/usr/sbin / /bin/bash --login 6.进入编译目录 cd /sources export LFS=/sources LFS-Bootscripts-6.3
代码:
时间设置(Configuring the setclock Script)
代码:
设置bash下的键盘功能键设置
代码:
设置Bash Shell启动文件(The Bash Shell Startup Files)
代码:
设置本地网络名
代码:
设置hosts文件
代码:
设置网络的静态地址
代码:
设置DNS
代码:
建立fstab文件
代码:
安装内核Linux-2.6.22.5
代码:
如果之前下载了UTF-8编码文字显示补丁,那么这里可以将这两个补丁打入内核 patch -Np1 -i $LFS/utf8-kernel-2.6.22.5-core-1.patch patch -Np1 -i $LFS/utf8-kernel-2.6.22.5-fonts-1.patch
代码:
如果在建立虚拟机的时候是选择的BusLogic的SCSI磁盘,那么应该在Device Drivers->SCSI device support->SCSI low-level drivers下加入BusLogic SCSI support的支持,可以采用编译到内核来避免未用initrd脚本来加载模块而导致启动失败 如果想支持网络则应该在Device Drivers->Networking support->Ethernet (10 or 100Mbit)加入AMD PCnet32 PCI support的支持,可以采用编译到内核也可以编译成模块的方式 如果想支持声卡则应该在Device Drivers->Sound->Advanced Linux Sound Architecture->PCI devices加入(Creative) Ensoniq AudioPCI 1371/1373的支持,编译成模块即可 文件系统的支持,需要根据之前将目标系统分区格式化的情况而定,使用了什么文件系统就需要加入该文件系统的支持,因之前采用的是Xfs文件系统,因此在File Systems->XFS support加入XFS的支持,可以采用编译到内核来避免未用initrd脚本来加载模块而导致启动失败 如果之前给内核加入了显示UTF-8编码文字的补丁的话,那么这里需要加入framebuffer的支持才能使补丁生效,在Device Drivers->Graphics support中加入Support for frame buffer devices,并选择上VESA VGA graphics supports,这里将其编译到内核中 同时还需要加入framebuffer字体支持,在Device Drivers->Graphics support->Console display driver support中加入Framebuffer Console support并选择上Select compiled-in fonts,选上VGA 8x16 font这一种字体就可以了,这里将这些选择都编译到内核中 可以保存退出了
代码:
安装Grub,使系统能启动,这里设置需要根据情况而修改,这里以之前介绍的分区设置为例:
代码:
输入setup (hd0) quit 设置grub启动菜单
代码:
将menu.lst连接到/etc目录下
代码:
退出制作环境:
代码:
现在已经完成了lfs的安装,可以重新启动来运行我们自己的系统咯! Grub启动界面 启动完成 (转载请保持文章的完整性,请注明作者和出处) 作者:孙海勇(冲天飞豹) Email:youbest@sina.com 2008年2月10日 更新日志: 2008年2月10日:本文发布。 2008年2月12日: 将chown -R root:root $LFS/tools误写为chwon -R root:root $LFS/tools 已改正过来 由linuxsir上的"糊涂"发现并报告 2008年2月12日: 在目标系统的/etc/profile中增加 alias ls="ls --color" export PS1='/u:/w/$ ' 2008年3月3日: 修改命令 gcc -dumpspecs | sed 's@^/lib/ld-linux.so.2@/tools&@g' / > `dirname $(gcc -print-libgcc-file-name)`/specs 为 gcc -dumpspecs | sed 's@^/lib/ld-linux.so.2@/tools&@g' > `dirname $(gcc -print-libgcc-file-name)`/specs 原因,为前面的“>”是输入符号,而在命令输入过程中系统会自动出现一个“>”,为避免新手误解,修改该命令表达方式。 由cublog上的“飞天老鼠”指出。 2008年3月3日: 修改命令 ./configure.gnu --prefix=/usr / -Dman1dir=/usr/share/man/man1 -Dman3dir=/usr/share/man/man3 -Dpager="/usr/bin/less -isR" 为 ./configure.gnu --prefix=/usr / -Dman1dir=/usr/share/man/man1 / -Dman3dir=/usr/share/man/man3 / -Dpager="/usr/bin/less -isR" 原因为笔误,缺少两个断行符号。 由cublog上的“embeddedarmlinux”指出 2008年3月16日: 修改笔误 rm-rf gcc-3.4.3 改为 rm -rf gcc-4.1.2 由linuxsir上的“yagng”指出 2008年7月6日: 修改笔误 tar xvf /lfs-sources/findutils-4.2.31.tar.bz2 改为 tar xvf /lfs-sources/findutils-4.2.31.tar.gz 由cublog上的“坚硬的贝壳”指出 2008年7月6日: 修改笔误 在第六章中glibc的locale安装部分 mkdir -pv /tools/lib/locale 改为 mkdir -pv /usr/lib/locale 由cublog上的“Leon”指出 2008年7月7日: 增加显示UTF-8编码文字 给内核打上我制作的UTF-8编码文字显示补丁,这样可以让制作出来的系统在带有framebuffer普通的终端下(非X环境)就可以直接显示出中文及其它语言的文字,并且可以同屏显示多国文字。
__________________
我的第一本图书出版了! http://blogold.chinaunix.net/u/13265/showart.php?id=2409099 青橄榄在入口的时候是苦的,过了一会你就可以长久的品味那淡淡而又清爽的甜味。 青橄榄 http://youbest.cublog.cn 青橄榄计划的第一步总算迈出来了,等待它的是万里长征. 做技术要有做技术的原则,决不拿技术做侵权的事情,更不能用来做违法的事情。工作丢了可以再找一个,原则丢了就找不回来了。 |