? ? ? ? ?第一次寫(xiě)讀書(shū)筆記,有什么套路呢?還沒(méi)來(lái)得及去學(xué)習(xí)?!秎inux kernel的設(shè)計(jì)與實(shí)現(xiàn)》真的是一本好書(shū),里面的東西解答了很多工作中的疑問(wèn)。如顯示地調(diào)用schedule()進(jìn)行調(diào)度,系統(tǒng)調(diào)用__syscalln(),一些數(shù)據(jù)結(jié)構(gòu)函數(shù)經(jīng)常在kernel 協(xié)議棧中遇到,中斷注冊(cè)和中斷上下文,軟中斷,tasklet,鎖,定時(shí)器,內(nèi)存管理slab...
第15章 進(jìn)程地址空間
? ? ? ?進(jìn)程只能訪問(wèn)有效內(nèi)存區(qū)域內(nèi)的內(nèi)存地址。每個(gè)內(nèi)存區(qū)域也具有相關(guān)權(quán)限如對(duì)相關(guān)進(jìn)程有可讀、可寫(xiě)、可執(zhí)行屬性。如果一個(gè)進(jìn)程訪問(wèn)了不在有效范圍中的內(nèi)存區(qū)域,或以不正確的方式訪問(wèn)來(lái)有有效地址,那么內(nèi)核就會(huì)終止該進(jìn)程,并返回“Segmentation Fault”這個(gè)經(jīng)典的錯(cuò)誤。內(nèi)存區(qū)域包含內(nèi)存對(duì)象如:
-可執(zhí)行文件代碼的內(nèi)存映射,稱(chēng)為代碼段(text section);
-可執(zhí)行文件的已初始化全局變量的內(nèi)存映射,稱(chēng)為數(shù)據(jù)段(data section);
-包含未初始化全局變量,也就是bss段的零頁(yè)(頁(yè)面中的信息全部為0值,所以可用于映射bss段等目的)的內(nèi)存映射;(bss段,因?yàn)槲闯跏蓟淖兞繘](méi)有對(duì)應(yīng)的值,所以并不需要存放在可執(zhí)行對(duì)象中,但是C標(biāo)準(zhǔn)強(qiáng)制規(guī)定未初始化的全局變量要被賦予特殊的默認(rèn)值,所以?xún)?nèi)核要將變量(未被賦值的)從可執(zhí)行代碼載入內(nèi)存中,然后將零頁(yè)映射到該片內(nèi)存上,于是這些未初始化變量就被賦予了0值,這樣做避免了在目標(biāo)文件中顯示地進(jìn)行初始化,減少了空間浪費(fèi))。
-用于進(jìn)程用戶空間棧的零頁(yè)的內(nèi)存映射;
-每一個(gè)諸如C庫(kù)或動(dòng)態(tài)連接程序等共享庫(kù)的代碼段、數(shù)據(jù)段和bss段也會(huì)被載入進(jìn)程的地址空間。
? ? 內(nèi)核使用內(nèi)存描述符結(jié)構(gòu)體表示進(jìn)程的地址空間,該結(jié)構(gòu)包含了和進(jìn)程地址空間有關(guān)的全部信息。內(nèi)存描述符由mm_struct結(jié)構(gòu)體表示,定義在文件<linux/sched.h>中,所有的mm_struct結(jié)構(gòu)體通過(guò)自身的mmlist域連接中一個(gè)雙向鏈表中,該鏈表的首元素是init_mm內(nèi)存描述符,代表init進(jìn)程的地址空間。
? ? ?內(nèi)存區(qū)域(VMA)由vm_area_struct結(jié)構(gòu)體描述,包含相關(guān)的mm_struct結(jié)構(gòu)體域。進(jìn)程的地址空間通過(guò)mmap和mm_rb(紅-黑樹(shù))描述包含的全部?jī)?nèi)存區(qū)域。
?可以使用/proc文件系統(tǒng)和pmap(1)工具查看給定進(jìn)程的內(nèi)存空間和其中包含的內(nèi)存區(qū)域。
mmap()和do_mmap()創(chuàng)建進(jìn)程的地址空間。內(nèi)核使用do_mmap(),用戶空間使用mmap()。
當(dāng)用程序訪問(wèn)一個(gè)虛擬地址時(shí),必須將虛擬地址轉(zhuǎn)化為物理地址,地址的轉(zhuǎn)換通過(guò)頁(yè)表才能完成。Linux中使用三級(jí)頁(yè)表轉(zhuǎn)換地址。
未完待續(xù)...