博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何提交内核补丁--checkpatch.pl使用【转】
阅读量:6293 次
发布时间:2019-06-22

本文共 1211 字,大约阅读时间需要 4 分钟。

转自:

转自: http://blog.csdn.net/ganggexiongqi/article/details/7032625#

 

补丁检测:./scripts/checkpatch.pl xxx.patch

这个时候补丁就制作成了,但是还要使用内核提供的补丁检测工具检测一下补丁的正确性,应为我们发布的补丁不能把很明显错误带进去。

  1. helight@Zhwen:linux-2.6$ ./scripts/checkpatch.pl 0001-clean-up-code-style-on-samples-tracepoints-tracepoin.patch   
  2. total: 0 errors, 0 warnings, 9 lines checked  
  3.   
  4. 0001-clean-up-code-style-on-samples-tracepoints-tracepoin.patch has no obvious style problems and is ready for submission.  
  5. helight@Zhwen:linux-2.6$   

 

 
使用checkpatch.pl输出的主要错误或警告:
 

scripts/checkpatch.pl输出的错误或警告有很多种,其中有一些比较具有代表性的,如下所示。在编写的阶段就应当充分注意它们。

错误

 换行符为DOS格式(CR+LF)。

 行首、行尾有多余的空格。

 不是用制表符,而是用空格缩进。

 switch语句和case语句的缩进不一致。

 函数定义块(block)以外的“{”写在独立的行中。

 注释符使用的是“//”。

 全局变量或静态变量是明确指定以0初始化的。

 前括号“(”或“[”后面有多余的空格。

 后括号“)”或“]”前面有多余的空格。

 逗号“,”后面没有空格。

 if、for、while的前括号“(”前面没有空格。

 else未与if块结尾的“}”写在同一行。

 使用了将来要废弃的头文件或函数。

 补丁内没有Signed-off-by行。

警告

 补丁内含有的路径起点不是内核树的根目录。

 1行的长度超过80字。

 制表符前面有空格。

 const关键词的使用方法有问题。

 printk()没有指定输出级别(KERN_*)。

 goto的分支终点的标签label缩进。

 用“{}”括住了只有1行的代码块。

 使用了volatile修饰符。

 kmalloc()的返回值已经转换。

小结

使用scripts/checkpatch.pl可以在投稿前检查补丁的格式。将补丁列入邮件列表时,经常可以看到“未按照规则编写,请修改”的提示。一定要在发布前检查补丁的格式,才能集中对补丁内容进行讨论。

参考文献

 Documentation/CodingStyle(内核源文档)

—Munehiro IKEDA

转自: http://book.2cto.com/201302/16274.html

你可能感兴趣的文章
01 iOS中UISearchBar 如何更改背景颜色,如何去掉两条黑线
查看>>
对象的继承及对象相关内容探究
查看>>
Spring: IOC容器的实现
查看>>
Serverless五大优势,成本和规模不是最重要的,这点才是
查看>>
Nginx 极简入门教程!
查看>>
iOS BLE 开发小记[4] 如何实现 CoreBluetooth 后台运行模式
查看>>
Item 23 不要在代码中使用新的原生态类型(raw type)
查看>>
为网页添加留言功能
查看>>
JavaScript—数组(17)
查看>>
Android 密钥保护和 C/S 网络传输安全理论指南
查看>>
以太坊ERC20代币合约优化版
查看>>
Why I Began
查看>>
同一台电脑上Windows 7和Ubuntu 14.04的CPU温度和GPU温度对比
查看>>
js数组的操作
查看>>
springmvc Could not write content: No serializer
查看>>
Python系语言发展综述
查看>>
新手 开博
查看>>
借助开源工具高效完成Java应用的运行分析
查看>>
163 yum
查看>>
第三章:Shiro的配置——深入浅出学Shiro细粒度权限开发框架
查看>>