使用老的LINUX版本进行内核代码分析在很多人看来是一种“避实就虚”的“卑鄙”手段。因为老的LINUX版本代码较为简单,分析起来基本不费“吹灰之力”,所以为很多“高手”所不齿。而对于很多新手而言,学习老代码似乎觉得有点让人看不起,或者自己有点看不起自己,最“酷”的莫过于捧着最新版本的内核源代码去“啃”;再者,有些新手对于学习老代码的作用有些怀疑,毕竟这些代码已成为历史,现在运行的系统代码较之那些之前的老代码简直是“面目全非”,甚至基本找不到老代码的影子,此时会对学习这些老代码的必要性产生怀疑,本人之前也是抱此怀疑。于是本人就去找最新的版本去看,去研究,比如国内比较有名的关于LINUX内核源代码分析的书《LINUX内核源代码情景分析》上下册。这本书分析的是LINUX2.4内核早期版本代码,相比较现在的2.6版本而言,这也算是老版本了。读过此书的人恐怕都深有体会,这个体会不是说读完了(真是精神可嘉)这本书感觉受益匪浅,而是感觉相当的痛苦,坦白的说,如果没有对操作系统有深刻的理解并且之前接触过操作系统编程,恐怕只能获得一个非常泛泛的理解。因为其传授的知识太多,一方面让我们不知所措,另一方面也感觉自己“内功”过于薄弱,无法承受这种“上乘武功“。那么之后(最近几年)出版的由同济大学赵炯博士所写的《LINUX-0.11完全注释》可以说对于很多LINUX内核爱好者而言帮助很大。LINUX-0.11内核版本在如今真可算得上是”古董“了。不过我想研读过这本书的读者肯定收获颇丰。而且之后当我们试图去分析较新版本的内核时,或者再去研读其它较新版本的有关内核分析的文章时,有种似曾相识之感,而且理解上也变得容易。原因很简单,中国有句古语,”麻雀虽小,五脏俱全“,LINUX-0.11内核版本虽然很小,但是是一个可以运行的操作系统版本,我们研读这本书了解了组成一个可运行操作系统需要完成的工作,通过代码实例可以更深刻的理解操作系统的各种概念。对于很多读者而言包括本人在内,之前对于操作系统”心存敬畏“,可是现在在很多人面前我都敢说,”哦,操作系统实现并不复杂,只是比较麻烦…“。早期代码的分析可以让我们把握问题的实质,从本文分析的主题网络部分代码来看,这点尤为突出。从LINUX-0.96C版本开始就包含网络代码,本人从0.96C版本开始,对网络部分代码进行过系统分析,一直到1.3.0版本,可以将这之前的版本都归为早期版本,这些版本有一个共同特点,即网络部分所有代码都在一个文件夹中,每种协议的实现都只是一个文件与之对应(接近1.3.0版本的代码,某些协议开始有多个文件对应),而此之后的版本(从1.3.0开始,包括1.3.0)开始进行细分,这一方面代码更加完善所以也就更加庞大,另一方面随着代码的逐渐成熟,层次关系更加明确。如现在对于内核数据包的封装结构sk_buff,对于早期代码而言并没有专门的处理文件,而现在对于此结构就有一个专门的操作函数集,集中放置在sk_buff.c文件中。
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
全部0条评论
快来发表一下你的评论吧 !