久久首页
免费软件
网络时尚
网络学堂
专题讨论
网络资源
网络游戏
网络文档
网络产品
网站导航: 首页 > 操作系统 > Linux Kernel HOWTO 中译版 > 5.修补核心 文档讨论

Linux Kernel HOWTO 中译版

后退 5.修补核心 前进

2004-02-14 Brian Ward 译者: C.W.Huang & Asd L. Chen http://www.math.psu.edu/ward/
 
5.1 使用补丁文件

核心的小幅更新是以补丁文件的方式发行.例如,如果你的版本是 1.1.45 ,而且你注意到出现了一个 `patch46.gz' 可以用来升级它,这代表你可以藉由使用这个补丁文件将版本升级到 1.1.46.你也许会想要先备份原始程序代码(`make clean' 然后 `cd /usr/src; tar zcvf old-tree.tar.gz linux' 将会为你造出一份 tar 压缩文件,里面就是整个原始程序代码与其文件架构).

现在接著继续上面的例子,假设你已经取得了 `patch46.gz' 并放在 /usr/src 下. cd 到 /usr/src 然后执行 `zcat patch46.gz | patch -p0' (如果并不是压缩过的补丁文件,那么就执行 `patch -p0 < patch46'),你将会看到许多东西飞逝而过(或是慢慢跳过,如果你的计算机真的很慢的话)告诉你它正试著修补程序,以及是否成功.通常,这个过程快得无法仔细看清楚它的动作,所以你会无法确定它到底有没有成功地执行.所以你可能会想在 patch 指令中加上 -s 选项,告诉 patch 程序只报告错误讯息就好. (这样你就不会得到许多``嗨! 我的计算机正在做某些改变!''的感觉,不过你可能宁愿这样…) 那么就得找找看一些可能不是那么顺利的事.cd 到 /usr/src/linux 并找寻文件名结尾为 .rej 的文件.某些版本的 patch(比较旧的版本,它们可能是在比较早期的文件系统上编译的)会把这些没有成功的操作记录在文件名有 # 的文件里.你可以用 `find' 来替你找;

    find .  -name '*.rej' -print

会将现行目录及子目录下所有具 .rej 结尾的文件名印到标准输出.
如果一切正确无误的话,执行第三节跟第四节所讨论的 `make clean',`config' 以及 `dep'.

关于 patch 指令另外还有一些选项.如前所述,patch -s 将会抑制除了错误以外的所有其它讯息.如果你把核心原始程序代码放在 /usr/src/linux 以外的地方,在该目录下用 patch -p1 也可以乾净俐落的执行修补任务.其它的 patch 选项在在线手册(man page)里都有很详细的描述.

5.2 如果有错误发生

(注意: 本节提到的大部份是指旧版的核心)

通常最常发生的问题是当 patch 修改一个叫做 `config.in' 的文件时,这个文件看起来不怎么对劲,因为你修改了一些选项来配合你的机器.这个问题已经小心的注意过了,但还是可能有人会在较旧的版本上遭遇这个问题.要修正这个问题的话,查看 config.in.rej 这个文件里留下些什么讯息.有修改过的部份正常来说会在每一行开始的地方标上 `+' 和 `-'.查看有标记的附近几行,然后记得它们是设成 `y' 或是 `n'.现在编辑 config.in 档,然后在适当的地方把 `y' 改成 `n' 以及 `n' 改成 `y'.执行

    patch -p0 < config.in.rej

如果成功的话(没有错误),那么你就可以继续配置与编译的工作.这个 config.in.rej 档还是会留在那里,但是你可以砍掉它.

如果你仍然遭遇其它问题,那么可能是你安装了一份损坏的补丁文件.如果 patch 显示 `previously applied patch detected: Assume -R?',你可能使用了一些比你目前的版本编号还低的补丁文件; 如果你回答 `y',它会尝试将你的程序代码降级,而且几乎一定会失败; 如此,你就需要重新取得一份新的原始程序代码.

要还原到修补前的状态的话,在原先的补丁文件上执行 `patch -R'.

当补丁文件真的失败的时候,最好的办法是从一个乾净的原始程序代码(例如从 linux-x.x.x.tar.gz 文件其中之一)开始,再重新执行.

5.3 砍掉 .orig 文件

只要做过几次修补以后,那些 .orig 的文件将会开始堆积.例如,我的一个 1.1.51 版的程序代码最后一次做清扫是在 1.1.48 版(我想是吧).删除这些 .orig 文件会节省许多的磁盘空间.

    find .  -name '*.orig' -exec rm -f {} ';'

将会替你照料这件事.某些版本的 patch 会用 ~ 来代替 .orig.
有其它更好的的办法可砍掉这些 .orig 档,就是利用 GNU 的 xargs:

    find .  -name '*.orig' | xargs rm

或是更安全但有些罗嗦的方法:
    find . -name '*.orig' -print0 | xargs --null rm --

5.4 其它的补丁文件

有一些并不是由 Linus 发行的其它补丁文件出现(我将称之为``非标准的'').如果你使用了它们,Linus 的补丁文件可能会而无法正确地执行,那么你不是得将它们还原就是得因此而去修改原始程序代码或是补丁文件.这个工作对初学者通常是很讨厌,所以如果你不想去修改原始程序代码(结果通常不大好),在使用 Linus 的补丁文件之前先还原这些非标准的补丁文件,或重新安装新的程序代码.然后试试栈锴标准的补丁文件能不能用.如果不能的话,那么要不你就继续使用旧的核心,试著修改补丁文件使其能用,要不就等待(可能是乞求)新版非标准补丁文件出现.

非标准的补丁文件有多普遍? 你有可能曾经听过它们.我使用 Bill Paul 的不闪烁补丁文件来修改我的虚拟控制台,因为我讨厌会闪烁的游标(这个补丁文件经常为新版核心而更新).由於大部份较新的设备驱动程序都已经被发展成可载入模组形式,因此许多非标准的补丁文件的重要性已逐渐降低.

 
后退 目录 前进
4.编译核心 6.附加的套件
 
发表评论 关闭窗口
 相关内容
 
 文档分类
操作系统
网络服务
编程语言
数据库
RFC请求注解
基础原理
软件使用
硬件参考
解决方案
 文章搜索
 
网站简介 | 广告服务 | 编程支持 | 设计服务 | 诚邀合作 | 访客留言
Copyright © 1999-2004 99NET. All Rights Reserved
版权所有 久久网络工作室
Email:webmaster@99net.net