diff 命令用法

1、”-u”:表示在比较结果中输出上下文中一些相同的行,这有利于人工定位

2、“-r“:表示递归比较各个子目录下的文件

3、“-N“:将不存在的文件当作空文件

4、“-w“:忽略对空格的比较

5、“-B“:忽略对空行的比较

例如:假设Linux-2.6.22.6目录中是原始的内核,Linux-2.6.22.6_ok目录中是修改后的内核,可以使用以下命令制作补丁文件linux-2.6.22.6_ok.diff(原始目录在前,修改过的目录在后)

diff  –urN -w -B  linux-2.6.22.6  linux-2.6.22.6_ok  >  linux-2.6.22.6.diff

由于linux-2.6.22.6是标准的代码,可以从网上自由下载,要发布的linux-2.6.22.6_ok中所做的修改时,只需要提供补丁文件linux-2.6.22.6_ok.diff(它通常是很小的)

patch 命令被用来打补丁----就是依据补丁文件来修改原始文件。比如对于上面的例子,可以使用以下命令将补丁文件linux-2.6.22.6_ok.diff 应用到原始目录linux-2.6.22.6上去。假设linux-2.6.22.6_ok.diff 和linux-2.6.22.6位于同一个目录下.

cd  linux-2.6.22.6

patch   -p1  <  ../linux-2.6.22.6_ok.diff

patch 命令中最重要的选项是“-pn”: 补丁文件中指明了要修改的文件的路径,“-pn”表示忽略路径中第n个斜线之前的目录。

如何打内核补丁

make kernel_menuconfig 里面存在了打补丁的过程,在更新已打过的patch的话就需要先make clean ,再make menuconfig , 再make kernel_menuconfig, 此时就会打上补丁,那么想更新的话就把原来的补丁删了,再make kernel_menuconfig,然后再把新内核和改动的内核对比,再按照下面的方法打补丁即可

内核打补丁后,需要再运行这个脚本

diff-urNwB build_dir/linux-brcm5830_sxxx-prolin2/linux-3.6.5/drivers/video/backlight/pwm_bl.c pwm_bl.c > drivers-video-backlight-pwm_bl.c.patch

 

补丁里必须在第一行加入diff打补丁命令

diff -urNwB

linux-3.6.5/drivers/video/backlight/pwm_bl.c linux-3.6.5/drivers/video/backlight/pwm_bl.c >

drivers-video-backlight-pwm_bl.c.patch

diff -urNa linux-3.0.56_old linux-3.0.56_new > out.patch

perl spldiff.pl < usb.patch

patch里就可以出现.orig

这是做了拆分补丁的动作

补丁里必须在第一行加入diff打补丁命令

spldiff.pl代码:

 #use warnings;
use strict;
no strict 'refs'; my %seen = ();
my $pf; while (<>) {
if (/^diff\s+\S+\s+.+?\/(\S+)/) {
$pf = $;
$pf =~ s/\//-/g;
unless (exists $seen{"$pf"}) {
open("$pf", ">$pf.patch");
$seen{"$pf"} = ;
}
} else {
s/(^---\s).+?\/(\S+)/$1linux-3.6.\/$.orig/;
s/(^\+\+\+\s).+?\/(\S+)/$1linux-3.6.\/$/;
print {"$pf"} $_;
}
}
make kernel_menuconfig 里面存在了打补丁的过程,在更新已打过的patch的话就需要先make clean ,
再make menuconfig , 再make kernel_menuconfig, 此时就会打上补丁,那么想更新的话就把原来的补丁删了,
再make kernel_menuconfig,然后再把新内核和改动的内核对比,再按照下面的方法打补丁即可 第一步 首先要提取一个干净的内核; svn co ….
cp configs/brcm5830-prolin2-defconfig .config
make menuconfig
进入patch目录下把补丁都删了
make V=s kernel_menuconfig
这样就会在build_dir目录下产生一个干净的linux内核 第二步 产生一个服务器上的原有内核 svn co ….
cp configs/brcm5830-prolin2-defconfig .config
make menuconfig
进入patch目录下把补丁都要保留
make V=s kernel_menuconfig
这样就会在build_dir目录下产生一个有patch提交过的linux内核 第三步 注意: 对比服务器的内核和原来的内核的区别,如果你所需要修改的文件原来的内核中没有,那么直接打补丁即可,如果所要修改的内核文件已经有了补丁,那么就要更新这个补丁即可。 diff -urNa linux-3.0.56_old linux-3.0.56_new > out.patch 打补丁命令 perl spldiff.pl < out.patch 拆分补丁,生成你所需要的补丁
欢迎交流
如有转载请注明出处

新浪博客:http://blog.sina.com.cn/u/2049150530
博客园:http://www.cnblogs.com/sky-heaven/
知乎:http://www.zhihu.com/people/zhang-bing-hua

最新文章

  1. Drupal 8.2.4安装简体中文步骤
  2. ECMAScript5之Object
  3. C# 部分语法总结(入门经典)
  4. springmvc的form标签
  5. centos 安装smplayer
  6. 转:Android设置全局变量
  7. XgCalendar日历插件动态添加参数
  8. mac版tomcat修改端口无法访问,80端口无法访问
  9. shell-----sed命令详解
  10. 用spark导入数据到hbase
  11. JVM回收器与调优
  12. 【已采纳】最快获取package和activity的方式
  13. 029_mount bind挂载
  14. hdoj:2050
  15. OpenStack Mitaka/Newton/Ocata/Pike 各版本功能贴整理
  16. eclipse操作(备忘)
  17. NRF51822之DFU使用手机升级
  18. 使用JSP实现输出(web基础学习笔记二)
  19. 第75天:jQuery中DOM操作
  20. windows CMD命令大全及详细解释和语法

热门文章

  1. [luogu4268][bzoj5195][USACO18FEB]Directory Traversal
  2. Hihocoder 1329 平衡树&#183;Splay(平衡树)
  3. BellmanFord 最短路
  4. sqlserver 导入数据出现 无法创建 OLE DB 取值函数。请查看列元数据是否有效
  5. sudALSA lib dlmisc.c:236:(snd1_dlobj_cache_get) Cannot open shared library /usr/lib/alsa-lib/libasound_module_pcm_pulse.so
  6. java代码示例(7-1)
  7. 离线方式部署Ambari2.6.0.0
  8. Port Forwarding in Windows
  9. 函数和常用模块【day06】:xml模块(六)
  10. springcloud报错集合