當(dāng)前位置:首頁(yè)文章首頁(yè) 新聞中心 搶鮮播報(bào)

分享閱讀linux內(nèi)核代碼的幾個(gè)技巧

作者:  來源:  發(fā)布時(shí)間:2011-4-28 12:44:41  點(diǎn)擊:
這些技巧都是平時(shí)我自已在閱讀的時(shí)候總結(jié)的,想到哪就說到哪了,其實(shí)我總結(jié)的技巧遠(yuǎn)不止這些,但是先說這些吧。后面想到了再補(bǔ)充,只有在拿到代碼做分析的時(shí)候遇到實(shí)際的問題時(shí),才能見招拆招,想些辦法。
其實(shí)linux內(nèi)核源碼還是比較難跟蹤的,我剛開始閱讀內(nèi)核源碼的時(shí)候,感覺很多東西經(jīng)常找著找著就失去頭緒了,很郁悶。
通過一些閱讀后發(fā)現(xiàn)內(nèi)核也就那么幾招用的比較多,摸清楚其脾氣后,剩下的就是耐心了。
1.我曾經(jīng)用過一陣VI,裝了一堆插件后折騰了一陣,發(fā)現(xiàn)還是無法感受其推崇者所說的那一堆好處,還是喜歡用sourceinsight。好了,說正題了。首先我們要解決的就是函數(shù)或者變量找不到定義地方的問題,表現(xiàn)在sourceinsight上就是那個(gè)變量是黑的,到處找不到。
比如我們看們看到:
int bus_register(struct bus_type * bus)
{
...
subsys_set_kset(bus, bus_subsys);
retval = subsystem_register(&bus->subsys);
...
}
其中的bus_subsys。
找了一下bus_subsys找不到定義的地方,肯定是內(nèi)核和我們躲貓貓,這時(shí)候我們可以是否查找一些明顯的“定義痕跡”,比如在bus_subsys中的subsys或者說_subsys。果然有新發(fā)現(xiàn)。我們找到了這么一個(gè)宏。
#define decl_subsys(_name,_type,_uevent_ops) \
struct subsystem _name##_subsys = { \
.kset = { \
.kobj = { .name = __stringify(_name) }, \
.ktype = _type, \
.uevent_ops =_uevent_ops, \
} \
}
得,我們回過頭在包含有bus_register的源文件及頭文件中查找一下,果然找到了static decl_subsys(bus, &ktype_bus, NULL);這么一行代碼。
像這種東西我不是很建議一找不到就直接去網(wǎng)上找,關(guān)于內(nèi)核的文章網(wǎng)上雖然很多,但都不會(huì)細(xì)到所有的細(xì)節(jié)都有,你總有獨(dú)立處理問題的時(shí)候,為什么我們不提前讓自已多鍛煉一下呢?
2.順序問題,內(nèi)核有很多的順序,比如初始化的順序,比如我們有module_init,__initcall等等,一來編譯的時(shí)候文件夾和文件有順序,另外不同的宏包含的東西順序也是有講究的,所以在分析模塊的時(shí)候一定要注意這個(gè),這個(gè)東西只能說是注意了,如果對(duì)一個(gè)模塊不熟悉的時(shí)候,不可能做到全部都了解,像我有時(shí)候也會(huì)落下一些東西忘記分析,但是隨著看內(nèi)核的時(shí)候越久,內(nèi)核那些慣用的手法見多了后,就發(fā)現(xiàn)不外如是,也就那三瓜子兩棗。
3.我們要解決內(nèi)核運(yùn)行時(shí)那一堆指來指去的指針的問題。這個(gè)是我自已調(diào)試用的土方法,我就用dump_stack在關(guān)鍵的地方打印出順序就行了。因?yàn)槲覀冏龅氖乔度胧皆O(shè)備,很多時(shí)候不能用KGDB這些高級(jí)工具在線調(diào),而且這種方法基本不增加其它的性能開銷。
4.有多個(gè)定義不知道用哪個(gè)。這個(gè)基本是因?yàn)長(zhǎng)INUX支持的CPU比較多造成的。
我們可以用GDB靜態(tài)分析,也可以用objdump和nm等工具來精確定位一些函數(shù)和變量,也可以根據(jù)宏來一步一步分析,比如是mips的那么我們就進(jìn)mips看,這樣一步一步來。
5.具備一些意識(shí),你現(xiàn)在面對(duì)的是操作系統(tǒng),不僅僅是只有C文件和頭文件的應(yīng)用,MAKEFILE,鏈接文件,Kconfig都應(yīng)該是你的朋友。尤其在看一個(gè)模塊或者一小部分你感興趣的代碼的時(shí)候,首先可以用MAKEFILE和KCONFIG來縮小你需要關(guān)注的范圍。其實(shí)關(guān)于MAKEFILE和KCONFIG的重要性,fudan_abc在他那個(gè)LINUX那些事之我是USB中強(qiáng)調(diào)的比較多,但是說實(shí)話,fudan_abc那文章看了玩是挺好玩的,可惜感覺好像看了沒啥用,就是知道了一堆概念,不能串起來,我不知道是我的理解能力不行,還是任僑偉同志壓根沒有講清楚。呵呵。

文章評(píng)論

軟件按字母排列: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z